inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

오브젝트 - 설계 원칙편

6-2. 명령 쿼리 분리 원칙으로 부수효과 관리하기

6-2 명령이라도 성공여부는 어떻게 하는 게 좋을까요

해결된 질문

94

Hika Maeng

작성한 질문수 20

0

자바 클래스 라이브러리들 조차도 대부분의 명령에 boolean을 반환하죠.

 

이게 고민인데 명령인 메소드는 반드시 void인가 하는 점입니다.

객체지향 소프트웨어-테스트 소프트웨어-설계

답변 2

0

조영호

클라이언트 입장에서 메서드 실행이 종료되면 정상적으로 객체의 상태가 변경된 것입니다.

Player 클래스의 move 메서드를 참고해 주세요. 🙂

0

Hika Maeng

그건 영호님은 정상 변경에 실패한건 예외로 하는게 맞다는 파시군요.

0

조영호

CQS 방식으로 인터페이스를 구성하는 경우에는 그렇습니다.

만약 CQS 방식이 오퍼레이션 사용을 복잡하게 만들거나 상태 변경 실패를 정상 플로우의 일부로 간주하고 싶은 경우에는 CQS 방식을 버리고 반환값을 사용하는 쪽으로 트레이드오프하는게 좋겠죠.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. Hika Maeng님, 질문 주셔서 감사합니다.

명령형 메서드의 반환 타입에 대한 고민은 객체지향 설계에서 종종 중요한 주제가 됩니다. Java 라이브러리에서도 boolean 값을 반환하여 작업의 성공 여부를 나타내는 경우가 많지만, 이는 콘텍스트에 따라 다르게 접근할 수도 있습니다.

명령형 메소드의 설계 방향

  1. void를 통한 선언적 코드: 명령은 객체의 상태를 변경하는 동작이기 때문에, 반환값을 제공하지 않는 것이 일반적입니다. 이는 코드의 의도를 명확히 하여, 메소드가 상태 변화를 위한 것임을 나타냅니다.

  2. boolean 반환: 경우에 따라 메서드가 실행된 결과의 성공 또는 실패 여부를 반환하는 것은 유용할 수 있습니다. 예를 들어, 파일 저장 메서드에서 저장에 성공했는지 실패했는지를 반환하는 것이 이해와 처리에 도움될 수 있습니다.

  3. 예외 처리 활용: 작업이 실패한 경우 예외를 던지는 것도 한 가지 방법입니다. 이는 제어 흐름을 명확히 하고, 실패의 원인을 명확하게 처리할 수 있습니다.

실무적 적용

  • 비즈니스 로직의 명확성: 비즈니스 로직의 흐름을 명확하게 하기 위해 명령형 메소드가 무엇을 의도하고 있는지에 따라 반환 타입을 결정해야 합니다. 메서드에 따라 반환값이 있는 것이 흐름을 더 명확하게 한다면 반환값을 추가할 수 있습니다.

  • 일관성 유지: 중요한 것은 프로젝트에서 일관된 설계를 유지하며, 팀이 이해하기 쉽도록 명령형 메서드의 반환 방식을 정하는 것이 좋습니다.

관련된 설계 논의가 이루어진 질문이 있으니, 이를 참고하시면 더 깊이 있는 이해에 도움이 되실 수 있을 것입니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

레이어드 아키텍처에서 도메인 중심 패키지 구조를 적용하거나 변화하는 시점이 있을까요?

1

48

2

tryMove(..) 메서드 ArrayIndexOutOfBoundsException 제보

1

67

2

5-4 Sealed Interface는 주로 모든 케이스 검증이 필요할 때 사용하나요?

1

465

1

Game, Player, Room간의 관계에 대한 질문을 드려요

1

109

2

6-2 보호 로직 중복 이슈

1

110

2

3-2 메서드를 얼마나 작게 나누는게 적절한가요?

1

134

3

4-2 값 객체 질문

1

97

2

7-3 Reader의 소유권 이동에 관해

1

60

2

디자인 패턴에 대해선 어떤 생각을 가지고 계신지 궁금합니다.

2

115

1

8-5 책임 분리를 통한 중복 코드 제거 과정에서 특정 조합은 불가능할 때

2

495

2

인스턴스 증가에 대한 우려

2

132

2

6-2. 명령과 쿼리 분리 원칙 질문

2

493

2

9-1 사소한 강의자료 오류

1

86

2

7-3 상속을 이용한 중복 제거 질문 있습니다!

3

1156

1

함수형 스타일에 대해선 어떻게 생각하시나요?

1

108

2

값 객체 활용에 대해

1

140

2

실례지만 여기에 후기 올립니다.

2

556

3

동일성과 동등성 설명이 바뀐 것 같습니다.

1

119

2

인터페이스명이 변경된 걸까요??

0

92

2

player 내부에 worldmap

3

149

2

9-6 순환참조인거 같은데..

0

116

2

8-5 오타

0

67

2

7-5 자막오타

0

60

2

7-5 자막오타

0

60

2