RentalCard 의 calculateLateFee 메서드 구현이 잘못된 것 같습니다.
안녕하세요.
calculateLateFee 메서드에 작성해주신 코드 중 아래 부분에 오류가 있는 것이 아닌지 확인 부탁드립니다.
private void calculateLateFee(RentalItem rentalItem, LocalDate returnDate) {
if (returnDate.compareTo(rentalItem.getOverdueDate()) > 0) {
int point = Period.between(rentalItem.getOverdueDate(), returnDate).getDays() * 10;
this.lateFee.addPoint(point); //문제
}
}아래처럼 수정되어야 하는 것이 아닌지 질문드립니다.
private void calculateLateFee(RentalItem rentalItem, LocalDate returnDate) {
if (returnDate.compareTo(rentalItem.getOverdueDate()) > 0) {
int point = Period.between(rentalItem.getOverdueDate(), returnDate).getDays() * 10;
this.setLateFee(this.lateFee.addPoint(point)); //수정
}
}감사합니다.
Câu trả lời 2
1
tkwoo님 안녕하세요. 강의자입니다.
네 지적하신 점이 맞습니다. 제가 코드의 결함을 인지하고 제공하는 소스코드에는 이후 변경하였는데,
동영상 상에는 공지를 제대로 하지 못했네요.
죄송합니다. 다시 확인해서 공지를 하도록 하겠습니다.
지적 감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다.
tkwoo님이 질문해 주신 것처럼 calculateLateFee 메서드의 구현에서 지적한 부분은 코드의 불변성 또는 메서드의 반환되는 객체의 상태를 올바르게 갱신하는 부분에서 발생하는 문제로 보입니다.
우선 원래 코드에서는 this.lateFee.addPoint(point); 라는 메서드를 사용하고 있는데, 이는 lateFee라는 객체에 포인트를 추가하려고 하지만 addPoint 메서드가 새로운 객체를 반환하고 그렇지 않으면 올바르게 사용되지 않을 가능성이 있습니다. 만약 addPoint 메서드가 불변 객체 패턴을 따르고 새로운 LateFee 객체를 반환한다면, this.setLateFee(this.lateFee.addPoint(point));처럼 후속적으로 반환된 객체를 현재 객체에 설정하는 방식이 더 적절합니다.
이와 연관된 논의들은 별도의 게시판에서도 활발히 다루어졌습니다. 아래 링크를 참고하시면 더욱 깊이 있는 이해를 도울 수 있을 것입니다:
- 보상트랜잭션 후 클라이언트 알림 방법 등: 비동기 통신에서 상태 변경 및 오버듀 처리 관련 논의.
- VO, Entity 궁금한 부분이 있습니다.: Value Object와 Entity 패턴의 사용 및 상태 변경에 관한 심도 있는 논의.
각 링크에서 제공되는 상세한 설명과 토론을 통해 문제 해결에 도움이 될 수 있을 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
도메인 모델에서 관계와 규칙을 구분하는 방법
0
29
2
user-service jwt
0
27
2
애그리거트 질문있습니다!
0
21
2
DDD 는 마이바티스와 잘 맞지 않는건가요?
0
38
1
스프링부트 버전 문의드립니다.
0
28
1
gRPC 실무에서 질문
0
30
2
Orchestration SAGA 패턴 보상에 대한 질문입니다.
0
46
2
6강 - 해시태그 모델의 샤딩 전략에 대하여, 분산 정도(데이터 편중)와 트랜잭션 성능의 trade off 상황 발생 시에 대한 고민
0
35
2
강의보다 바로 여쭤봅니다.
0
72
2
Aggregate 하위에 꼬리를 무는 Entity 는?
0
133
2
헥사곤 아키텍쳐 관련하여 문의드립니다.
2
167
2
VO 클래스의 불변 필드 선언을 하지 않으신 이유?
0
211
2
UserCase가 많은데... 이유?
0
502
1
음성 부분이 너무 깨지는데...
0
357
1
CQRS 질문 드립니다.
0
360
1
강의 음성 및 영상
0
349
1
domain.model.event에 정의되는 객체들에 대한 질문이 있습니다
0
367
1
수업에 사용한 소스코드 문의
0
595
1
EDA 이해
0
467
1
보상트랜잭션 후 클라이언트 알림 방법 등
0
356
1
MSA 구조에서 공통 클래스
0
900
2
@Repository 두 곳에서 사용하시는 이유
0
458
1
Entity와 VO에 대해..
0
763
1
DTO 클래스의 위치에 대해 질문있습니다!
1
759
1

