작성
·
33
0
SOLID 5가지 원칙 중에 OCP 개방-폐쇄 원칙을 설명하는 도중 7:25 쯤에 private MemberRepository memberRepository = new MemoryMemberRepository(); 에서 JdbcMemberRepository() 객체 구현으로 변경할 시 private MemberRepository memberRepository = new JdbcMemberRepository(); 라고 나오는데 OCP의 원칙이 구현 객체를 변경하려면 클라이언트 코드를 변경해야 한다고 설명되어있습니다. 그런데 방금 변경된 코드에서 보면 private MemberRepository memberRepository 이 코드는 동일하게 되어있다는 것입니다. 도대체 무엇때문에 김영한 강사님께서 코드 변경 안하고 좀 안되지 않냐고 말씀하신지 알려주세요.
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
소진 김님, 질문 주신 OCP(Open-Closed Principle) 개방-폐쇄 원칙은 소프트웨어 개체가 확장에는 열려있어야 하지만 수정을 필요로 하지 않도록 설계되어야 한다는 원칙입니다. 즉, 새로운 기능을 추가할 때 기존 코드를 수정하는 것이 아니라, 기존 코드를 변경하지 않고도 기능을 확장할 수 있는 기능을 제공하는 것입니다.
질문에서 언급하신 부분은 김영한 강사님께서 “클라이언트 코드가 변경되는 것이 문제”로 설명하신 부분입니다. 여기서 클라이언트 코드를 변경하지 않아도 되려면, DI(Dependency Injection) 방식으로 주입해서 사용할 수 있도록 설계를 해야 합니다. 즉, private MemberRepository memberRepository = new MemoryMemberRepository();
와 같은 방식은 메모리에 직접적으로 종속되어 있지만, DI를 통해 생성자에서 외부로부터 MemberRepository
인터페이스를 구현한 객체를 주입받게 하면 private MemberRepository memberRepository;
와 같이 구현하고, 의존성 주입을 통해 다양한 구현체(MemoryMemberRepository, JdbcMemberRepository 등)를 사용 가능하게 됩니다.
이러한 설계는 코드의 유연성을 증가시키고 변경 시 유지보수를 용이하게 합니다. 따라서, 클라이언트 코드(즉, 서비스 클래스에서의 코드)가 변경되지 않고도 확장성을 유지할 수 있게 됩니다.
관련 질문과 답변은 다음 링크들을 참고하시면 도움이 될 것입니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.