개발
객체 지향 생활 체조 원칙 규칙 8 : 일급 컬렉션
ka0oll
2020. 5. 17. 13:05
일급 컬렉션이란?
특정 필터된 콜렉션 값을 래핑한 클래스를 의미한다.
규칙
콜렉션 이외에 다른 멤버변수는 없어야 한다.
이점
비지니스에 종속적인 자료구조
public class UserCars{
private final List<Car> cars;
public UserNames(List<Car> cars) {
if(cars.size() > 10) {
throw new Exception();
}
this.cars = cars;
}
}
컬렉션에 대해 비스니스 적인 제약을 둘수 있다.
예제와 같이 소유가능한 자동차의 갯수는 사이즈는 10개 미만으로 제한되도록 강제화 할수 있다.
해당 컬렉션에 대한 불변을 보장
as-is
List<Car> userCars = Arrays.as(new Car(), new Car())
userNames.add(new Car()); // 불변을 보장하지 못한다.
to-be
public class UserCars{
private final List<Car> cars;
public UserNames(List<Car> cars) {
if(cars.size() > 10) {
throw new Exception();
}
this.cars = cars;
}
}
cars접근하지 못하게 해 불변을 유지 할수 있다.
상태와 행위를 한곳에서 관리 할수 있어, 응집도가 높아진다.
as-is
public class User{
private List<Car> cars;
private Car getMainCar(){
return cars.stream().filter(isMain).findFirst();
}
}
public class Company{
private List<Car> cars;
private Car getMainCar(){
return cars.stream().filter(isMain).findFirst();
}
}
cars에 대한 상태와 행위가 한곳에서 이루어 지지 않아 코드에 중복이 발생햇다.
to-be
public class User{
private Cars cars;
private Car getMainCar(){
return cars.getMainCar();
}
}
public class Company{
private Carscars;
private Car getMainCar(){
return cars.getMainCar();
}
}
public class Cars {
private final List<Car> cars;
public Cars(List<Car> cars) {
this.cars = cars;
}
public getMainCar() {
retrun cars.stream().filter(isMain).findFirst();
}
}
Cars 일급 콜렉션 객체에서 상태와 행위가 관리되어지고 있다. 중복코드가 줄어들었다.
이름이 있는 컬렉션
as-is
List<Car> userCars = createUserCars();
List<Car> companyCars = createCompanyCars();
to-be
UserCars userCars = createUserCars();
CompanyCars companyCars = createCompanyCars();
변수명보단 클래스의 명으로 의미를 부여 하는게 더 용이하다.
변수명은 개발자마다 다를수도 있기때문이다.
CompanyCars에 대한 요구 사항 변경시 해당 클래스에만 반영하면 된다.