Java java지도 시간 종속성 반전 원리

종속성 반전 원리

Aug 26, 2024 am 06:32 AM

상위 모듈은 하위 모듈에 의존해서는 안 됩니다. 둘 다 추상화에 의존해야 합니다.

추상화는 세부 사항에 의존해서는 안 되며, 세부 사항은 추상화에 의존해야 합니다.

예를 통해 상위 모듈하위 모듈을 이해해 보겠습니다.

Dependency Inversion Principle

Flipkart와 같은 높은 수준의 전자상거래 앱에서는 ProductCatalog, PaymentProcessor 및 CustomerProfile로 분류될 수 있습니다(이들은 주요 비즈니스 기능 중 일부입니다)
이러한 비즈니스 기능은 위 이미지에 표시된 다른 모듈과 상호 의존합니다.

참고: 상단의 모듈은 상위레벨 모듈
이라는 비즈니스 기능에 더 가깝습니다. 하단의 모듈은 하위레벨 모듈

이라는 구현 세부 사항에 가깝습니다.

하위 수준 모듈은 SQLProductRepository, GooglePayService, WireTransfer, EmailSender 및 VoiceDialer입니다.

CustomerProfile(상위 모듈)과 Communication 모듈만 고려하면 Communication은 Low-level 모듈이지만 Communication, EmailSender 및 VoiceDialer만 고려하면 Communication은 High-level 모듈이 되고 EmailSender 및 VoiceDialer는 저수준 모듈입니다.

여기서 중요한 점은 상위모듈과 하위모듈의 개념이 절대적인 것이 아니라 상대적인이라는 개념입니다.

위의 이미지에 따르면 ProductCatalog는 SQLProductRepository에 따라 다릅니다. 즉, 상위 수준 모듈이 하위 수준 모듈에 종속되지만 이는 DIP의 첫 번째 정의와 직접적으로 충돌합니다

.


ProductCatalog → SQLProductRepository 관계를 살펴보고 더 분석해 보겠습니다.

import java.util.List;
/*
 * High-Level module
*/
public class ProductCatalog {
    public void listAllProducts(){
        SQLProductRepository sqlProductRepository = new SQLProductRepository();
        List<String> allProductsNames = sqlProductRepository.getAllProductNames();
        //Display all products names
    }
}
로그인 후 복사
/*
 * Low-level module 
*/
import java.util.Arrays;
import java.util.List;
public class SQLProductRepository {
    public List<String> getAllProductNames(){
        return Arrays.asList("soap","toothpaste");
    }
}
로그인 후 복사

ProductCatalog는 SQLProductRepository에 직접적으로 의존하므로 이는 분명히 DIP 정의 1을 위반하는 것입니다(정의에 따르면 고수준 모듈과 저수준 모듈은 모두 추상화에 의존해야 합니다

)

이 문제를 정의 1에 따라 수정하겠습니다.


인터페이스 ProductRepository 생성

import java.util.List;

public interface ProductRepository {
    public List<String> getAllProductNames();
}
로그인 후 복사


SQLProductRepository에서 이 인터페이스 구현

/*
 * Low-level module 
*/
import java.util.Arrays;
import java.util.List;
public class SQLProductRepository  implements ProductRepository{
    @Override
    public List<String> getAllProductNames(){
        return Arrays.asList("soap","toothpaste");
    }
}
로그인 후 복사

마지막으로 상위 수준 모듈 ProductCatalog의 경우 SQLProductRepository를 직접 인스턴스화해서는 안 됩니다
. 동일한 작업을 위해 ProductFactory 클래스를 사용하겠습니다

public class ProductFactory {
    public static ProductRepository create(){
        return new SQLProductRepository();
    }
}
로그인 후 복사


ProductFactory를 사용하여 SQLProductRepository를 인스턴스화합니다

/*
 * High-Level module
*/
import java.util.List;

public class ProductCatalog {
    public void listAllProducts(){
        ProductRepository productRepository = ProductFactory.create();
        List<String> allProductsNames = productRepository.getAllProductNames();
        //Display all products names
    }
}
로그인 후 복사

참조 개체는 ProductRepository이므로 SQLProductRepository와 긴밀한 결합이 없습니다.

수정 후 새 종속성은 다음과 같습니다

Dependency Inversion Principle


위 변경 사항은 DIP 정의 1에 따릅니다.
위의 코드 변경은 DIP의 두 번째 정의도 따릅니다. 즉, 추상화는 세부 사항에 의존해서는 안 되고, 세부 사항은 추상화에 의존해야 합니다. 위의 이미지에서 볼 수 있듯이 SQLProductRepository는 그 반대가 아니라 ProductRepository에 의존합니다. 이 원리를 의존성 역전의 원리라고 부르는 이유는


의존성 주입과 의존성 반전
Even though they are related, they are not the same and can not be used interchangeably 
로그인 후 복사

의존성 주입 이해:


ProductCatalog에서는 팩토리 메서드 ProductFactory.create()를 사용하여 SQLProductRepository 개체의 인스턴스를 가져옵니다.
인스턴스 생성 프로세스를 팩토리 클래스 ProductFactory에 위임하지만 초기화 프로세스는 여전히 ProductCatalog 클래스를 사용합니다.
이상적으로는 ProductCatelog 클래스가 인스턴스화를 트리거하는 방법과 시기를 걱정하는 것을 원하지 않습니다.

요청하지 않고도 인스턴스화된 ProductRepository 클래스를 ProductCatalog에 제공하면 어떻게 될까요?


그래서 Main 클래스 ECommerceMainApplication은 팩토리 메소드 ProductFactory.create()를 사용하여 ProductRepository의 인스턴스를 생성하고 이 인스턴스는 ProductRepositroy 클래스 생성자의 인수로 전달됩니다.

public class ECommerceMainApplication {
    public static void main(String agrs[]) {
        ProductRepository productRepository = ProductFactory.create();
        ProductCatalog productCatalog = new ProductCatalog(productRepository);
        productCatalog.listAllProducts();
    }
}
로그인 후 복사


ProductCatalog 클래스를 적절하게 업데이트한 후

import java.util.List;

public class ProductCatalog {

    private ProductRepository productRepository;

    public ProductCatalog(ProductRepository productRepository) {
        this.productRepository = productRepository;
    }

    public void listAllProducts(){
        List<String> allProductsNames = productRepository.getAllProductNames();
        //Display all products names
        allProductsNames.forEach(product-> System.out.println(product));
    }
}
로그인 후 복사


이제 ProductCatalog는 언제 어디서든 SQLProductRepository 개체를 자유롭게 사용할 수 있습니다. 더 이상 SQLProductRepository 개체를 자체적으로 생성하는 것에 대해 걱정할 필요가 없습니다. 즉, 종속성 인스턴스화에 대해 걱정하는 ProductCatalog 대신 우리는 종속성을 ProductCatalog에 주입
합니다. 이것이 의존성 주입


의 개념입니다.

제어 반전 - IOC

DIP(Dependency Inversion 원리)의 일부는 아니지만 밀접하게 연관되어 있습니다

위와 같은 코드로 이해해보자

ProductCatalog 클래스에는 ProductRepository 개체를 사용하는 생성자가 있습니다.

ProductCatalog를 호출하는 클래스는 ProductRepository의 개체를 제공하거나 주입합니다. 이 경우 ECommerceMainApplication입니다.
ProductCatalog 클래스 외부에서 주입이 발생하더라도 주입은 여전히 ​​프로그램의 기본 흐름 중에 발생합니다. 즉, 프로그램 실행의 메인 스레드에서 주입이 발생합니다.

주 제어 흐름이 주입과 완전히 분리되도록 모든 주입이 별도의 스레드나 별도의 컨텍스트에서 모두 발생하도록 하려면 어떻게 해야 할까요?

이는 Spring(Java)과 같은 프레임워크를 사용하여 달성할 수 있습니다.

Dependency Inversion Principle

Spring은 프로그램의 주요 흐름과 다른 맥락을 실행합니다
Spring은 클래스의 필수 종속성을 주입하는 작업을 처리합니다. 따라서 클래스 객체를 인스턴스화하려면 코드에서 직접 수행하는 대신 Spring에 클래스 객체를 제공하도록 요청하세요.
Spring 프레임워크는 객체 인스턴스화에 필요한 모든 종속성을 살펴본 다음 모든 종속성을 주입하고 객체를 인스턴스화한 후 이를 기본 제어 흐름에 다시 제공합니다.
따라서 종속성 주입에 대한 제어는 Spring 프레임워크에 완전히 위임되며 메일 제어 흐름에서는 발생하지 않습니다.
이 개념을 IOC(Inversion of Control)라고 하며 Spring을 Inversion of Control Container 또는 간단히 IOC 컨테이너

라고 합니다.

위 내용은 종속성 반전 원리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

<gum> : Bubble Gum Simulator Infinity- 로얄 키를 얻고 사용하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora : 마녀 트리의 속삭임 - Grappling Hook 잠금 해제 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Nordhold : Fusion System, 설명
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

회사의 보안 소프트웨어가 응용 프로그램이 실행되지 않습니까? 문제 해결 및 해결 방법은 무엇입니까? 회사의 보안 소프트웨어가 응용 프로그램이 실행되지 않습니까? 문제 해결 및 해결 방법은 무엇입니까? Apr 19, 2025 pm 04:51 PM

일부 애플리케이션이 제대로 작동하지 않는 회사의 보안 소프트웨어에 대한 문제 해결 및 솔루션. 많은 회사들이 내부 네트워크 보안을 보장하기 위해 보안 소프트웨어를 배포 할 것입니다. ...

분류를 구현하고 그룹의 일관성을 유지하기 위해 이름을 숫자로 변환하려면 어떻게합니까? 분류를 구현하고 그룹의 일관성을 유지하기 위해 이름을 숫자로 변환하려면 어떻게합니까? Apr 19, 2025 pm 11:30 PM

많은 응용 프로그램 시나리오에서 정렬을 구현하기 위해 이름으로 이름을 변환하는 솔루션, 사용자는 그룹으로, 특히 하나로 분류해야 할 수도 있습니다.

맵 구조를 사용하여 시스템 도킹에서 필드 매핑 문제를 단순화하는 방법은 무엇입니까? 맵 구조를 사용하여 시스템 도킹에서 필드 매핑 문제를 단순화하는 방법은 무엇입니까? Apr 19, 2025 pm 06:21 PM

시스템 도킹의 필드 매핑 처리 시스템 도킹을 수행 할 때 어려운 문제가 발생합니다. 시스템의 인터페이스 필드를 효과적으로 매핑하는 방법 ...

Intellij Idea는 로그를 출력하지 않고 스프링 부팅 프로젝트의 포트 번호를 어떻게 식별합니까? Intellij Idea는 로그를 출력하지 않고 스프링 부팅 프로젝트의 포트 번호를 어떻게 식별합니까? Apr 19, 2025 pm 11:45 PM

IntellijideAultimate 버전을 사용하여 봄을 시작하십시오 ...

데이터베이스 쿼리 조건을 구축하기 위해 엔티티 클래스 변수 이름을 우아하게 얻는 방법은 무엇입니까? 데이터베이스 쿼리 조건을 구축하기 위해 엔티티 클래스 변수 이름을 우아하게 얻는 방법은 무엇입니까? Apr 19, 2025 pm 11:42 PM

데이터베이스 작업에 MyBatis-Plus 또는 기타 ORM 프레임 워크를 사용하는 경우 엔티티 클래스의 속성 이름을 기반으로 쿼리 조건을 구성해야합니다. 매번 수동으로 ...

Java 객체를 어레이로 안전하게 변환하는 방법은 무엇입니까? Java 객체를 어레이로 안전하게 변환하는 방법은 무엇입니까? Apr 19, 2025 pm 11:33 PM

Java 객체 및 배열의 ​​변환 : 캐스트 유형 변환의 위험과 올바른 방법에 대한 심층적 인 논의 많은 Java 초보자가 객체를 배열로 변환 할 것입니다 ...

Redis 캐시 솔루션을 사용하여 제품 순위 목록의 요구 사항을 효율적으로 실현하는 방법은 무엇입니까? Redis 캐시 솔루션을 사용하여 제품 순위 목록의 요구 사항을 효율적으로 실현하는 방법은 무엇입니까? Apr 19, 2025 pm 11:36 PM

Redis 캐싱 솔루션은 제품 순위 목록의 요구 사항을 어떻게 인식합니까? 개발 과정에서 우리는 종종 a ... 표시와 같은 순위의 요구 사항을 처리해야합니다.

전자 상거래 플랫폼 SKU 및 SPU 데이터베이스 설계 : 사용자 정의 속성과 귀속없는 제품을 모두 고려하는 방법은 무엇입니까? 전자 상거래 플랫폼 SKU 및 SPU 데이터베이스 설계 : 사용자 정의 속성과 귀속없는 제품을 모두 고려하는 방법은 무엇입니까? Apr 19, 2025 pm 11:27 PM

전자 상거래 플랫폼에서 SKU 및 SPU 테이블의 디자인에 대한 자세한 설명이 기사는 전자 상거래 플랫폼에서 SKU 및 SPU의 데이터베이스 설계 문제, 특히 사용자 정의 판매를 처리하는 방법에 대해 논의 할 것입니다 ...

See all articles