찾다
Javajava지도 시간저는 5년 동안 일해왔지만 아직도 파사드 모델을 이해하지 못합니다!


자, 테마를 입력해 보겠습니다. 오늘은 디자인 패턴에 외관 모드. 门面模式用贴切的生活故事,以及真实项目场景来讲设计模式,最后用一句话来总结这个设计模式。

故事

开发的朋友都知道,后端开发通常都是:

controller---servie---dao/mapper/repository

但是,我问过很多人,熟悉门面模式不?有的工作五年了都不知道。

今天老田,就带你来看看门面模式。

门面模式概述

门面模式(Facade Pattern

적절한 인생 이야기와 실제 프로젝트 시나리오로 이야기합니다

디자인 패턴

, 그리고 마지막으로 이 디자인 패턴을 한 문장으로 요약합니다. 🎜🎜

🎜Story🎜 🎜

🎜개발 친구들은 모두 백엔드 개발이 일반적으로 다음과 같다는 것을 알고 있습니다: 🎜

controller---servie---dao/mapper/repository🎜

🎜 하지만 저는 많은 사람들에게 물어봤는데, 파사드 모델에 대해 잘 알고 있나요? 5년 동안 일했는데도 모르는 사람도 있어요. 🎜🎜오늘은 Lao Tian이 파사드 모드를 보여드리겠습니다. 🎜

🎜외관 모드 개요🎜 🎜

🎜Facade 모드(외관 패턴)은 모양 모드라고도 하며 하위 시스템 인터페이스 그룹에 액세스하기 위한 통합 인터페이스를 제공합니다. 주요 특징은 서브시스템을 보다 쉽게 ​​사용할 수 있도록 상위 수준의 인터페이스를 정의한다는 점이며 구조적 디자인 패턴에 속합니다. 🎜🎜영어:🎜

하위 시스템의 인터페이스 집합에 통합 인터페이스를 제공합니다. Facade는 하위 시스템을 더 쉽게 사용할 수 있도록 하는 상위 수준 인터페이스를 정의합니다.

실제로 우리 모두는 일상적인 코딩 작업에서 의도적으로 광범위하게 Facade 패턴을 사용합니다. 아니면 의도치 않게. 상위 수준 모듈이 여러 하위 시스템(2개 이상의 클래스 개체)을 예약해야 할 때마다 이러한 하위 시스템을 캡슐화하기 위해 의식적으로 새 클래스를 만들고 상위 수준 모듈이 이러한 기능을 간접적으로 더 쉽게 호출할 수 있도록 간소화된 인터페이스를 제공합니다. 하위 시스템.

Cases in life

파사드 모델에 관해서는 삶의 사례가 많습니다.

사례 1: 업무를 처리하기 위해 은행에 가면 프론트 데스크가 여러분을 맞이할 것입니다. 그러면 프론트 데스크에서 어떤 업무를 해야 하는지 물어보고 하나씩 안내해 줄 것입니다. 그래서 우리는 돌아다니면서 해당 비즈니스 창구를 찾을 필요가 없습니다. 이 프론트 데스크 직원은 외관 모델에 해당합니다.

사례 2: 집을 지을 때 시공업체가 없으면 시멘트 작업자, 전기 기술자, 장식 작업자 등을 직접 찾아야 합니다. 그러나 계약자가 있는 경우에는 이러한 작업을 수행할 필요가 없습니다. 배선을 수리하려면 전기 기술자가 필요하다고 계약자에게 직접 알릴 수 있습니다. 이 계약자는 외관 모델로 이해될 수 있습니다.

사례 3: controller,也可以理解为门面模式,比如说获取用户账户信息,先查UserService获取用户信息,然后查UserAccountService백엔드에서 개발한 사용자 계정 정보.

Facade 모드에 적용 가능한 시나리오

소프트웨어 시스템에서 Facade 모드는 다음과 같은 응용 시나리오에 적합합니다.

  • 복잡한 모듈이나 하위 시스템에 대한 외부 액세스를 위한 간단한 인터페이스를 제공합니다.
  • 하위 시스템의 독립성을 향상시키고 싶을 때.
  • 부득이한 일시적인 사유로 인해 하위 시스템에 버그나 성능 관련 문제가 발생할 수 있는 경우 Facade 모드를 통해 상위 수준의 인터페이스를 제공하여 클라이언트와 하위 시스템 간의 직접적인 상호 작용을 격리하여 코드 오염을 방지할 수 있습니다.

Facade 모드의 일반적인 작성 방법

간단한 Facade 모드를 구현하려면 코드를 사용하는 것이 더 좋습니다. 데모부터 시작하는 것이 가장 좋기 때문입니다.

비즈니스 시나리오: 이제 세 가지 서비스의 해당 메소드를 호출해야 합니다.

public class ServiceA {
    public void doA(){
        System.out.println("do ServiceA");
    }
}
public class ServiceB {
    public void doB(){
        System.out.println("do ServiceB");
    }
}

public class ServiceC {
    public void doC(){
        System.out.println("do ServiceC");
    }
}

파사드 모드가 도입되지 않으면 클라이언트는 이를 다음과 같이 호출합니다.

public class Client {
    public static void main(String[] args) {
        ServiceA serviceA=new ServiceA();
        ServiceB serviceB=new ServiceB();
        ServiceC serviceC=new ServiceC();

        serviceA.doA();
        serviceB.doB();
        serviceC.doC();
    }
}

매번 클라이언트는 많은 양의 서비스를 생성해야 합니다. 서비스 객체가 많다면 이 코드가 어색하지 않을까요? 반복되는 코드가 많을 겁니다.

실행 결과

do ServiceA
do ServiceB
do ServiceC

지금 참여합시다门面模式:

public class Facade {
    //是不是很像我们controller里注入各种service?
    private ServiceA serviceA = new ServiceA();
    private ServiceB serviceB = new ServiceB();
    private ServiceC serviceC = new ServiceC();

    public void doA() {
        serviceA.doA();
    }

    public void doB() {
        serviceB.doB();
    }

    public void doC() {
        serviceC.doC();
    }
}

클라이언트는 다음과 같습니다.

public class Client {
    public static void main(String[] args) {
        //轻轻松松的搞定,只需要创建门面这个对象即可
        Facade facade=new Facade();
        facade.doA();
        facade.doB();
        facade.doC();
    }
}

실행 결과:

do ServiceA
do ServiceB
do ServiceC

외관 패턴 UML 다이어그램


저는 5년 동안 일해왔지만 아직도 파사드 모델을 이해하지 못합니다!

이 UML과 결합됨 다이어그램을 통해 은행 프론트 데스크 직원과 계약업체의 사례를 검토하면 외관 패턴을 이해하기가 더 쉽습니다.

파사드 모드의 캐릭터

위 그림에서 볼 수 있듯이 파사드 모드에는 주로 2개의 캐릭터가 포함되어 있습니다.

  • 외관 문자(외관): 파사드 역할이라고도 하며 시스템의 통합된 외부 인터페이스입니다. Facade):也叫作门面角色,是系统对外的统一接口。
  • 子系统角色(Service):可以同时有一个或多个Service。每个Service都不是一个单独的类,而是一个类的集合。Service们并不知道Facade的存在,对于Service们而言,Facade 只是另一个客户端而已(即FacadeServiceAServiceBServiceC
하위 시스템 역할(서비스 ) : 하나 이상의 서비스. 각Service는 별도의 클래스가 아니지만, 수업 모음. 서비스 사람들은 모릅니다Facade의 존재, 서비스용, Facade는 또 다른 클라이언트입니다(예: 외관ServiceA, ServiceB, ServiceC투명).

외관 패턴 확장

장점

● 시스템 상호의존성 감소 생각해 보세요. Facade 모드를 사용하지 않으면 외부 액세스가 하위 시스템으로 직접 들어가고, 둘 사이에는 강한 결합 관계가 있고, 당신이 살면 나도 살 것입니다. 강력한 의존성은 시스템 설계의 결과입니다. 받아들일 수 없는 일이지만, 파사드 패턴의 출현은 이 문제를 매우 잘 해결합니다. 모든 종속성은 파사드 객체에 있으며 하위 시스템과는 아무런 관련이 없습니다. 🎜🎜● 유연성 향상 의존성은 줄어들고 유연성은 자연스럽게 높아집니다. 서브시스템이 내부적으로 어떻게 변경되더라도 파사드 객체에 영향을 주지 않는 한 자유롭게 이동할 수 있습니다. 🎜

● 提高安全性   想让你访问子系统的哪些业务就开通哪些逻辑,不在门面上开通的方法,你休想访问到 。

缺点

  • 当增加子系统和扩展子系统行为时,可能容易带来未知风险。
  • 不符合开闭原则。
  • 某些情况下,可能违背单一职责原则

大神们是如何使用的

Spring中也是有大量使用到门面模式,比如说

org.springframework.jdbc.support.JdbcUtils

再来看看其中的方法

public static void closeConnection(@Nullable Connection con) {
    con.close();
}
public static Object extractDatabaseMetaData(DataSource dataSource, DatabaseMetaDataCallback action)
   throws MetaDataAccessException {
    Connection con = null;
  try {
   con = DataSourceUtils.getConnection(dataSource);
   DatabaseMetaData metaData = con.getMetaData();
   if (metaData == null) {
      //.....
   }
   return action.processMetaData(metaData);
  }
}
......

都是给我封装好了方法,对于我们开发者来说,我只面向JdbcUtils这一个类就好了,我不用去管ConnectionResultSet等是怎么创建的,需要的时候,我调用JdbcUtils的对应方法即可获得对应的对象。

Mybatis中也是用到了门面模式,比如:

org.apache.ibatis.session.Configuration

Configuration中以new开头的方法,比如:

public Executor newExecutor(Transaction transaction) {
    return newExecutor(transaction, defaultExecutorType);
}
public MetaObject newMetaObject(Object object) {
    return MetaObject.forObject(object, objectFactory, objectWrapperFactory, reflectorFactory);
}

public ParameterHandler newParameterHandler(MappedStatement mappedStatement, Object parameterObject, BoundSql boundSql) {
    ...
    return parameterHandler;
}

public ResultSetHandler newResultSetHandler(Executor executor, MappedStatement mappedStatement, RowBounds rowBounds, ParameterHandler parameterHandler,
      ResultHandler resultHandler, BoundSql boundSql) {
   ...
    return resultSetHandler;
}

public StatementHandler newStatementHandler(Executor executor, MappedStatement mappedStatement){
   ...
}

对于调用这些方法的地方,他并不知道是怎么new出来的对象,只管使用就行了。

Tomcat中也有门面模式,比如:

org.apache.catalina.connector.RequestFacade

从名字就知道它用了门面模式。它封装了非常多的request操作,也整合了很多servlet-api以外的内容,给用户使用提供了很大便捷。同样,Tomcat针对ResponseSession也封装了对应的ResponseFacade类和StandardSessionFacade类,感兴趣的小伙伴可以深入了解一下。

PS:基本上所有以Facade结尾的类,都是使用到了门面模式。

참고자료: Tom의 디자인 패턴 강좌

Summary

알겠습니다. 이 글을 읽고 나면 Facade 모드가 실제로 매우 간단하다고 생각하시나요? 직장에서도 사용할 수 있나요? 사용할 수 있는지 생각해 보세요. 동시에 면접 시 자랑할 수도 있습니다.

위 내용은 저는 5년 동안 일해왔지만 아직도 파사드 모델을 이해하지 못합니다!의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 Java后端技术全栈에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Java의 플랫폼 독립성을 위협하거나 향상시키는 새로운 기술이 있습니까?Java의 플랫폼 독립성을 위협하거나 향상시키는 새로운 기술이 있습니까?Apr 24, 2025 am 12:11 AM

신흥 기술은 위협을 일으키고 Java의 플랫폼 독립성을 향상시킵니다. 1) Docker와 같은 클라우드 컴퓨팅 및 컨테이너화 기술은 Java의 플랫폼 독립성을 향상 시키지만 다양한 클라우드 환경에 적응하도록 최적화되어야합니다. 2) WebAssembly는 Graalvm을 통해 Java 코드를 컴파일하여 플랫폼 독립성을 확장하지만 성능을 위해 다른 언어와 경쟁해야합니다.

JVM의 다른 구현은 무엇이며, 모두 같은 수준의 플랫폼 독립성을 제공합니까?JVM의 다른 구현은 무엇이며, 모두 같은 수준의 플랫폼 독립성을 제공합니까?Apr 24, 2025 am 12:10 AM

다른 JVM 구현은 플랫폼 독립성을 제공 할 수 있지만 성능은 약간 다릅니다. 1. OracleHotspot 및 OpenJDKJVM 플랫폼 독립성에서 유사하게 수행되지만 OpenJDK에는 추가 구성이 필요할 수 있습니다. 2. IBMJ9JVM은 특정 운영 체제에서 최적화를 수행합니다. 3. Graalvm은 여러 언어를 지원하며 추가 구성이 필요합니다. 4. AzulzingJVM에는 특정 플랫폼 조정이 필요합니다.

플랫폼 독립성은 개발 비용과 시간을 어떻게 줄입니까?플랫폼 독립성은 개발 비용과 시간을 어떻게 줄입니까?Apr 24, 2025 am 12:08 AM

플랫폼 독립성은 여러 운영 체제에서 동일한 코드 세트를 실행하여 개발 비용을 줄이고 개발 시간을 단축시킵니다. 구체적으로, 그것은 다음과 같이 나타납니다. 1. 개발 시간을 줄이면 하나의 코드 세트 만 필요합니다. 2. 유지 보수 비용을 줄이고 테스트 프로세스를 통합합니다. 3. 배포 프로세스를 단순화하기위한 빠른 반복 및 팀 협업.

Java의 플랫폼 독립성은 코드 재사용을 어떻게 촉진합니까?Java의 플랫폼 독립성은 코드 재사용을 어떻게 촉진합니까?Apr 24, 2025 am 12:05 AM

Java'SplatformIndenceFacilitatesCodereScoderEByWatHeAveringByTeCodetOrunonAnyPlatformwitHajvm.1) DevelopersCanwriteCodeOnceforConsentEStentBehaviorAcRossPlatforms.2) MAINTENDUCEDSCODEDOES.3) LIBRRIESASHSCORAREDERSCRAPERAREDERSPROJ

Java 응용 프로그램에서 플랫폼 별 문제를 어떻게 해결합니까?Java 응용 프로그램에서 플랫폼 별 문제를 어떻게 해결합니까?Apr 24, 2025 am 12:04 AM

Java 응용 프로그램의 플랫폼 별 문제를 해결하려면 다음 단계를 수행 할 수 있습니다. 1. Java의 시스템 클래스를 사용하여 시스템 속성을보고 실행중인 환경을 이해합니다. 2. 파일 클래스 또는 java.nio.file 패키지를 사용하여 파일 경로를 처리하십시오. 3. 운영 체제 조건에 따라 로컬 라이브러리를로드하십시오. 4. visualVM 또는 JProfiler를 사용하여 크로스 플랫폼 성능을 최적화하십시오. 5. 테스트 환경이 Docker Containerization을 통해 생산 환경과 일치하는지 확인하십시오. 6. githubactions를 사용하여 여러 플랫폼에서 자동 테스트를 수행하십시오. 이러한 방법은 Java 응용 프로그램에서 플랫폼 별 문제를 효과적으로 해결하는 데 도움이됩니다.

JVM의 클래스 로더 서브 시스템은 플랫폼 독립성에 어떻게 기여합니까?JVM의 클래스 로더 서브 시스템은 플랫폼 독립성에 어떻게 기여합니까?Apr 23, 2025 am 12:14 AM

클래스 로더는 통합 클래스 파일 형식, 동적로드, 부모 위임 모델 및 플랫폼 독립적 인 바이트 코드를 통해 다른 플랫폼에서 Java 프로그램의 일관성과 호환성을 보장하고 플랫폼 독립성을 달성합니다.

Java 컴파일러는 플랫폼 별 코드를 생성합니까? 설명하다.Java 컴파일러는 플랫폼 별 코드를 생성합니까? 설명하다.Apr 23, 2025 am 12:09 AM

Java 컴파일러가 생성 한 코드는 플랫폼 독립적이지만 궁극적으로 실행되는 코드는 플랫폼 별입니다. 1. Java 소스 코드는 플랫폼 독립적 인 바이트 코드로 컴파일됩니다. 2. JVM은 바이트 코드를 특정 플랫폼의 기계 코드로 변환하여 크로스 플랫폼 작동을 보장하지만 성능이 다를 수 있습니다.

JVM은 다른 운영 체제에서 멀티 스레딩을 어떻게 처리합니까?JVM은 다른 운영 체제에서 멀티 스레딩을 어떻게 처리합니까?Apr 23, 2025 am 12:07 AM

멀티 스레딩은 프로그램 대응 성과 리소스 활용을 향상시키고 복잡한 동시 작업을 처리 할 수 ​​있기 때문에 현대 프로그래밍에서 중요합니다. JVM은 스레드 매핑, 스케줄링 메커니즘 및 동기화 잠금 메커니즘을 통해 다양한 운영 체제에서 멀티 스레드의 일관성과 효율성을 보장합니다.

See all articles

핫 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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