해결된 질문
작성
·
262
0
제가 자바에 대해 완전히 이해하고 있지 않은지
this.를 붙이고 getter/setter를 쓰는 거와
그냥 바로 getter/setter를 쓰는 것,
이 두 개가 다른 가 싶더라구요
OrderItem에서
getItem().~~; 을 보면
그냥 getter를 썼는데
Order에서
this.setOrderStatus(~);를 보면
this를 붙인 후 seter를 써서
제가 아는 걸 쥐어짜내보면
둘 다 똑같을 것 같은 느낌이 들긴 하는데;;
뭐가 다른 건가요 ?
class OrderItem{
..
public void cancel() {
getItem().addStockQuantity(count);
}
..
}
class Order {
..
public void cancel() {
if (delivery.getDeliveryStatus() != DeliveryStatus.READY) {
throw new IllegalStateException("이미 배송되었거나 배송중입니다.");
}
this.setOrderStatus(OrderStatus.CANCEL);
for (OrderItem orderItem : orderItemList) {
orderItem.cancel();
}
}
..
}
//아 또 갑자기 궁금한 게 생겼는데..
public class Order() {
..
private OrderStatus orderStatus;
..
public void cancel() {
if (delivery.getDeliveryStatus() != DeliveryStatus.READY) {
throw new IllegalStateException("이미 배송되었거나 배송중입니다.");
}
this.setOrderStatus(OrderStatus.CANCEL);
for (OrderItem orderItem : orderItemList) {
orderItem.cancel();
}
}
..
}
에서 this.setOrderStatus(OrderStatus.CANCEL); 이 아니라
orderStatus = OrderStatus.CANCEL; 로 해도
프록시 조회의 문제를 제외하면 상관 없을까요 ?
혹시 모르니 set을 통한 방법을 만들어 두는 게
안전한 방법인가요 ?
뭔가 이 질문은 부끄러운 질문 같은데.. 올려봅니다..
답변 1
2
안녕하세요, relate16 님. 공식 서포터즈 codesweaver 입니다.
.
1) 자바에서 this는 현재 객체 자기자신을 의미합니다. 그래서 일반적인 경우 this를 생략해도 문제없습니다. 특수한 경우에는 문제가 될 수 있습니다. (질문하신 내용에 있는 것처럼 프록시 객체에서는 this를 써서 문제가 되는 경우가 있습니다)
.
2) 주문 상태를 변경하기 위해 setOrderStatus()를 쓸것을 권장합니다. 객체지향적 프로그래밍 관점에서도 그렇지만, 주문상태가 변경되었을때 같이 처리되어야 할 다른 코드들이 있을 수 있기 때문입니다. 그래서 상태값만 변경하는 경우 문제가 발생할 수 있습니다.
감사합니다.
그렇군요 :] 감사합니다 !