조합 모드
부분-전체 패턴이라고도 하는 복합 패턴은 유사한 개체 그룹을 단일 개체로 처리하는 데 사용됩니다. 컴포지션 모드는 부분 및 전체 계층을 나타내는 데 사용되는 트리 구조에 따라 개체를 결합합니다. 이러한 유형의 디자인 패턴은 객체 그룹의 트리 구조를 생성하는 구조적 패턴입니다.
이 패턴은 자체 개체 그룹을 포함하는 클래스를 만듭니다. 이 클래스는 동일한 객체 그룹을 수정하는 방법을 제공합니다.
다음 예시를 통해 콤비네이션 모드의 사용법을 보여드립니다. 이 예는 조직 내 직원의 계층 구조를 보여줍니다.
Introduction
의도: 객체를 트리 구조로 결합하여 "부분-전체" 계층 구조를 나타냅니다. 구성 패턴을 통해 사용자는 단일 개체와 복합 개체를 일관되게 사용할 수 있습니다.
주요 해결 방법: 트리 구조 문제에서 단순 요소와 복잡한 요소의 개념을 모호하게 만듭니다. 클라이언트 프로그램은 복잡한 요소를 단순 요소와 동일한 방식으로 처리할 수 있으므로 클라이언트 프로그램의 내부 구조가 클라이언트 프로그램과 다릅니다. 복잡한 요소가 분리되었습니다.
사용 시기: 1. 개체의 부분-전체 계층 구조(트리 구조)를 표현하려고 합니다. 2. 사용자가 결합된 객체와 단일 객체의 차이를 무시하고 결합된 구조의 모든 객체를 균일하게 사용하기를 원합니다.
해결 방법: 가지와 잎은 통일된 인터페이스를 구현하고, 인터페이스는 가지 내부에서 결합됩니다.
키 코드: 브랜치는 내부적으로 이 인터페이스를 결합하고 Component를 포함하는 내부 속성 List를 포함합니다.
적용 예: 1. 산술 표현식에는 피연산자, 연산자 및 다른 피연산자가 포함되며, 여기서 다른 연산자는 연산 트리, 연산자 및 다른 피연산자일 수도 있습니다. 2. JAVA AWT 및 SWING에서는 Button과 Checkbox가 리프이고, 컨테이너가 브랜치입니다.
장점: 1. 상위 수준 모듈 호출이 간단합니다. 2. 노드는 자유롭게 추가할 수 있습니다.
단점: 조합 패턴을 사용할 때 잎과 가지의 선언은 인터페이스가 아닌 구현 클래스이므로 종속성 반전 원칙을 위반합니다.
사용 시나리오: 트리 메뉴, 파일 및 폴더 관리와 같은 부분 및 전체 시나리오.
참고: 정의되면 구체적인 클래스입니다.
Implementation
복합 모델 클래스로 처리되는 Employee 클래스가 있습니다. CompositePatternDemo, 데모 클래스에서는 Employee 클래스를 사용하여 부서 계층을 추가하고 모든 직원을 인쇄합니다.

1단계
Employee 개체 목록이 포함된 Employee 클래스를 만듭니다.
Employee.java
import java.util.ArrayList; import java.util.List; public class Employee { private String name; private String dept; private int salary; private List<Employee> subordinates; //构造函数 public Employee(String name,String dept, int sal) { this.name = name; this.dept = dept; this.salary = sal; subordinates = new ArrayList<Employee>(); } public void add(Employee e) { subordinates.add(e); } public void remove(Employee e) { subordinates.remove(e); } public List<Employee> getSubordinates(){ return subordinates; } public String toString(){ return ("Employee :[ Name : "+ name +", dept : "+ dept + ", salary :" + salary+" ]"); } }
2단계
Employee 클래스를 사용하여 직원 계층 구조를 만들고 인쇄합니다.
CompositePatternDemo.java
public class CompositePatternDemo { public static void main(String[] args) { Employee CEO = new Employee("John","CEO", 30000); Employee headSales = new Employee("Robert","Head Sales", 20000); Employee headMarketing = new Employee("Michel","Head Marketing", 20000); Employee clerk1 = new Employee("Laura","Marketing", 10000); Employee clerk2 = new Employee("Bob","Marketing", 10000); Employee salesExecutive1 = new Employee("Richard","Sales", 10000); Employee salesExecutive2 = new Employee("Rob","Sales", 10000); CEO.add(headSales); CEO.add(headMarketing); headSales.add(salesExecutive1); headSales.add(salesExecutive2); headMarketing.add(clerk1); headMarketing.add(clerk2); //打印该组织的所有员工 System.out.println(CEO); for (Employee headEmployee : CEO.getSubordinates()) { System.out.println(headEmployee); for (Employee employee : headEmployee.getSubordinates()) { System.out.println(employee); } } } }
3단계
출력을 확인합니다.
rreee