작성
·
183
답변 2
1
1
안녕하세요. 아리마님^^ 좋은 질문입니다.
임베디드 타입 Value Object여서, 충분히 공용으로 사용 가능한 것들을 주로 뽑게 됩니다. 예를 들어서 x,y를 합친 Point라던가, 기간이라던가 이런 부분들요. 쉽게 이야기해서 비즈니스에 잘 흔들리지 않는 조각들을 주로 뽑게 됩니다. (물론 비즈니스 의존적인 Value Object도 충분히 만들어 질 수 있습니다.)
이것도 결국 프로젝트 규모에서 차이가 납니다. 프로젝트가 작다면 공용으로 모으는게 효율적인데, 프로젝트 규모 크고 한 프로젝트 안에 큰 모듈이 여러가지 있다면, 우선 그 모듈 안에서 사용하는 것이 좋습니다.
예를 들어서 주문, 회원 이 둘을 다 가지고 있는 프로젝트이고, 개념상 소스코드는 한곳에서 관리되지만, 패키지를 크게 나누었다면, Value Object도 공용으로 가지기 보다는 모듈을 벗어나지 않고 사용하는게 좋겠지요.
왜냐하면 생일(예를 들어서) 같은 Value Object는 비즈니스 의존적이지 않는다 해도, 회원 모듈안에서만 사용될 확율이 높기 때문입니다. 따라서 공용으로 가져가면 응집성이 떨어집니다. 가격 같은 Value Object는 주문에서만 주로 사용하겠지요.
반면에 주소라는 Value Object는 회원, 주문 모두에서 사용될 수 있는데, 이런 것은 공용으로 가는게 좋습니다.
감사합니다~