강의

멘토링

로드맵

Inflearn brand logo image

인프런 커뮤니티 질문&답변

김정민님의 프로필 이미지
김정민

작성한 질문수

김영한의 실전 자바 - 기본편

문제와 풀이

접근 제어자 문제와 풀이

작성

·

82

0

=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오) 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오) 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오) 예

[질문 내용]
접근 제어자 문제와 풀이 질문 드립니다.

calculateTotalPrice 메서드로 따로 만든 내용이 displayItems() 의 로직과 중복되었는데, 강의에서는 따로 메서드로 빼서 작성하는 것이 변경 및 수정하는데 용이하다고 언급하셨습니다.

 

그 점에서 의문이 드는 것은, 그냥 calculateTotalPrice 메서드에서

 

int totalPrice 를 선언하고,

for 문에서 totalPrice += item.getTotalPrice()를 하면 더 간편하지 않은지 궁금합니다.

강사님께서 말씀하신 내용의 요지는 알겠으나, 그와 별개로 궁금한 점이라 질문드립니다.

답변 2

0

안녕하세요. 김정민님, 공식 서포터즈 y2gcoder입니다.

제가 질문을 잘 이해하지 못한 것 같습니다!

image.png

제가 이해하기로는 말씀하신 것처럼 calculateTotalPrice() 내부에 int totalPrice = 0;으로 선언 및 초기화가 되어있는 것 같은데 혹시 다른 의도로 해주신 질문이실까요?

 

감사합니다.

0

안녕하세요, 인프런 AI 인턴입니다. 김정민님.

질문 주신 내용은 메서드와 코드 중복에 관한 방법론적 접근에 대한 고민이라고 보여집니다. 강의에서는 주로 “변경 및 수정의 용이성”을 위해 메서드를 분리하여 설계하는 방식을 권장하고 있는 것인데요. 이는 객체지향 프로그래밍의 기본 철학 중 하나이고, “단일 책임 원칙”을 따르기 위한 방법 중 하나입니다.

🧐 주요 개념

  • 단일 책임 원칙: 하나의 메서드는 하나의 책임만 가져야 한다는 원칙입니다. 이는 메서드가 특정한 작업이나 기능에 국한되어 다른 작업과 혼합되지 않도록 하는 설계 방법입니다.

  • 유지보수성: 메서드를 분리하면 나중에 코드 수정 및 유지보수가 간편해집니다. 만약 버그 수정이나 기능 추가가 필요할 때 모든 로직이 한 메서드 안에 있다면 수정 작업이 복잡해질 수 있습니다.

📝 제안 & 설명

  • ‘displayItems()’ 메서드와 ‘calculateTotalPrice()’ 메서드를 분리하는 것은 그 각각의 목적이 다르기 때문입니다. 가령, ‘displayItems()‘는 상품의 목록 및 가격을 출력하는 역할을 할 것이고, ‘calculateTotalPrice()‘는 전체 금액을 계산하는 역할만 수행하도록 분리합니다.

  • 메서드를 분리하여 얻는 장점: 메서드 분리는 코드의 재사용성을 높이고, 코드 베이스를 간결하게 유지합니다. 이렇게 분리된 메서드는 다른 상황에서도 독립적으로 활용이 가능합니다.

기존 커뮤니티에도 이와 유사한 질문과 답변이 있어 아래 링크에서 더 자세한 내용을 참고할 수 있습니다:

위 정보를 통해 코드 관리 측면에서 메서드 분리를 고려해보시면 도움이 되리라 생각됩니다.

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

김정민님의 프로필 이미지
김정민

작성한 질문수

질문하기