inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

좋은 객체 지향 설계의 5가지 원칙(SOLID)

DIP(의존성 역전의 원칙)은 왜 의존성이 역전된다는 것인가요?

926

Umi

작성한 질문수 7

9

안녕하세요 영한님~ 강의 잘 듣고있습니다!

옛날부터 궁금했던 점이 하나 있는데 바로 의존성 역전의 원칙은 왜 의존성 역전이라고 표현하는가입니다.

의존성 역전의 원칙이 뭐하는 녀석이고, 왜 필요한 지는 알겠지만, 왜 의존성이 역전된다고 표현하는 지는 잘 모르겠어서요!

어떤 경우의 의존성과 비교했을 때 그 경우와 의존되는 방향이 역전되었기 때문인가요?

DIP가 사용되는 경우 사람은 추상적인 자동차 인터페이스에 의존해야지 구체적인 K3라는 구현체에 의존해서는 안된다고 할 수 있을텐데.

이와 반대로 추상적인 것이 아닌 구체적인 것에 의존해야하는 경우도 있기때문에 DIP가 사용되는 경우는 그 반대를 의미하는 "역전"이라고 부르는 건가요?

감사합니다!

spring oop

답변 2

14

김영한

안녕하세요. Umi님

맞습니다. 전통적인 개발 방법은 클라이언트 -> 구체 클래스를 의존합니다. 그런데 이제는 구체 클래스를 의존하는게 아니라 추상적인 부분에 의존하기 때문에 의존성이 역전 된다고 표현합니다. 자주 변하는 구체적인 것에 의존하다가 잘 변하지 않는 추상적인 부분에 의존하게 되는 것이지요.

클라이언트 -> 구체 클래스

그런데 여기서 재미있는 점은 클라이언트만 추상에 의존하는게 아니라 구체 클래스까지 추상에 의존하게 된다는 점입니다.

클라이언트 -> 추상 <- 구체 클래스

감사합니다.

5

Umi

그렇군요! 아무래도 요즘 세대에는 말씀해주신 "전통적인 개발 방법"에서의 클라이언트 -> 구현체에 의존하는 경우를 별로 접해볼 일이 없어서 그런지 역전이란 말이 잘 이해안되었는데...

감사합니다 영한님. ㅎㅎ 덕분에 이해가 잘 되었습니다.

구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?

0

46

2

MemberService의 인터페이스를 왜 사용하는지 궁금합니다.

0

72

1

롬복 @Setter를 써야 하는 상황이 있는건가요?

0

87

1

빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?

0

79

1

테스트 속도가 나중에 영향이 있을까요?

0

75

1

gradle 설정 안떠서 질문 남깁니다!

0

116

2

build.gradle로 프로젝트를 여는 이유

0

81

1

provider 사용하는 이유

0

85

1

다음 강의 뭘 들어야 할까요

0

123

2

프로토타입 빈, 직접 destroy 호출 안 할 경우

0

62

1

beanB

0

79

2

퀴즈다시풀기

0

63

1

Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ

0

90

2

"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.

0

63

3

run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>

0

102

2

도메인의 정의?

0

57

1

ApplicationContext 질문입니다.

0

60

1

@Scope의 proxyMode를 사용할때 단위 테스트 방법

0

86

2

ai api 선정하기 관련 질문

0

115

2

생성자 자동주입 관련해서

0

60

1

생성자 직접 호출 vs 팩토리 메서드 패턴

0

93

2

Spring에서 SessionScope와 RequestScope는 함께 사용되나요?

1

63

1

12:25

0

74

2

appConfig.xml 오류

0

124

1