Generic 명시를 해야 하나요? 말아야 하나요?
640
12 asked
강의 소스 코드 일부를 발췌했습니다.
@GetMapping("/api/v2/members")
public Result membersV2() {
List<Member> findMembers = memberService.findMembers();
//엔티티 -> DTO 변환
List<MemberDto> collect = findMembers.stream()
.map(m -> new MemberDto(m.getName()))
.collect(Collectors.toList());
return new Result(collect);
}
@Data
@AllArgsConstructor
class Result<T> {
private T data;
}
-질문-
DTO를 Result<T>로 만들었을 때,
- public Result<MemberDto> membersV2()
- public Result membersV2()
둘 중에 어떻게 작성하는게 더 좋은지 알 수 있을까요? 항상 타입을 명시하는 Result<MemberDto> 방식으로 사용해왔는데, 선생님 코드에는 뭐든지 이유가 있을 것 같아 이렇게 여쭤봅니다!
Answer 3
9
안녕하세요. pjok112님 좋은 질문입니다.
항상 타입을 명시하는 것이 가독성 유지보수 등에서 더 좋은 방법입니다.
다만 이 부분에서 생략해도 크게 문제가 없는 이유는 json 라이브러리가 타입을 명시하지 않아도, 인스턴스 타입으로 객체를 만들어내도록 설계되어 있기 때문입니다. 이게 객체를 json으로 만들때는 문제가 없는데, 반대로 json을 객체로 만들어야 하는 경우가 발생하면 타입이 없으면 문제가 됩니다.
실무에서는 가급적 타입을 넣어주는 것을 권장드립니다.
감사합니다.
1
안녕하십니까 선생님!!
질문과 답변을 보고 궁금증이 생겨 질문드립니다.
위의 상황에서 Result를 사용할 때
Result<List<MemberDto>>로 사용하는게 아닌가
싶었는데 Result<MemberDto>만 쓰는게 일반적인 것인가요??
강의 관련 외 질문입니다.
0
65
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
0
86
1
BeanCreationException
0
86
3
Update 후 UpdateMemberResponse 매핑할 때
0
46
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
98
2
페이징 + 검색조건 관련해서 질문드립니다.
0
70
1
Query Dsl Q파일 질문입니다.
0
81
1
루트 쿼리라는것은
0
58
1
메서드를 분리하는 기준
0
62
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
108
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
83
2
fetch join과 영속화와 OSIV의 관계
0
84
2
Distinct 사용 전 결과에 대한 의문
0
113
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
56
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
78
2
dto 필드 속 엔티티 여부
0
58
1
뷰템플릿 사용 시
0
76
2
Result 클래스 관련 질문
0
56
1
@PostConstruct 프록시 관련 질문드립니다
0
85
1
DTO 대신 Form 사용은 안되나요?
0
133
1
OSIV ON 상태일 때
0
95
1
fetch join VS fetch join 페이징 궁금증
0
179
2
양방향 연관관계 알아보는 법?
0
104
1
16강 17강 간단 정리 이게 맞을까요 ?
0
165
2

