Y: A family tree is also called a genealogy. It records the patriarchy family pedigree, people as the center, from the official history of the emperor and the chronicle of princes, chronology and so on evolved. It is a special document. In terms of its content, it is a document with civilian characteristics in the five thousand years of Chinese civilization. It records the historical maps of people and deeds of the blood groups of the same ancestor.
Now, how to implement little J’s family tree.
A brief version of little J’s family tree
Starting from the first generation of J at the top, it is recorded from generation to generation, which is obviously a tree structure. Now what little Y needs to do is to traverse the family tree of little J in the most appropriate way.
2. The combination mode of tree graph
1. Definition of combination mode
The composite mode is also called the composite mode, sometimes also called the partial-whole mode. It is mainly used to describe the relationship between parts and the whole. Objects are combined into a tree structure to represent the partial-whole hierarchical structure, so that users can use a single object and a composite object consistently.
2. Role introduction of composite mode (there are two implementations of composite mode: security mode and transparent mode)
-
Component Abstract Roles define common methods and properties that participate in composite objects, and can define some default behaviors or properties.
-
Leaf objects have no further branches, which are the smallest units to traverse.
-
Composite branch object, which combines branch nodes and leaf nodes to form a tree structure. The focus of combination mode is on the branch members.
3. Application scenarios of the combined mode
-
Whenever you have a tree structure or whenever you want to represent a relationship between part and whole, and that relationship can be deep, you want to think about composition patterns.
-
A scenario in which some modules or functions can be separated from a whole.
-
Maintain and display scenarios for partial-whole relationships.
4. Concrete realization of security mode and transparent mode
(1) Safe mode
① Abstract component
Public abstract class Component {// Both individual and whole have public void operation(){// write business logic}}Copy the code
② Branch member
Public Class Extends Component {private List<Component> componentArrayList = new ArrayList<Component>(); Components / / add a leaf or branch member public void the add Component (Component) {this.com ponentArrayList. Add (Component); } / / delete a member leaves or branches artifacts public void remove Component (Component) {this.com ponentArrayList. Remove (Component); } public List<Component> getChildren(){return this.componentArrayList; }}Copy the code
③ Leaf component
Public class Leaf extends Component {/* * extends Component public void operation(){* *} */}Copy the code
(4) the Client
Public class Client {public static void main(String[] args) {// Create a root. Root = new Composite(); root.operation(); // create a branch component Composite branch = new Composite(); // create a Leaf node Leaf = new Leaf(); Root. add(branch); branch.add(leaf); } public static void showTree(Composite root){for(Component C :root.getChildren()){if(c instanceof Leaf){ // leaf node c.oation (); }else{showTree((Composite)c); }}}}Copy the code
(2) Transparent mode
① Abstract component
Public abstract class Component {// Both the individual and the whole have public void operation(){// write business logic} // add a leaf or branch Component public abstract void add(Component component); Public abstract void remove(Component Component); Public abstract List<Component> getChildren(); }Copy the code
② Branch member
Public Class Composite extends Component {private ArrayList<Component> componentArrayList = new ArrayList<Component>(); Components / / add a leaf or branch member public void the add Component (Component) {this.com ponentArrayList. Add (Component); } / / delete a member leaves or branches artifacts public void remove Component (Component) {this.com ponentArrayList. Remove (Component); } public List<Component> getChildren(){return this.componentArrayList; }}Copy the code
③ Leaf component
Public class Leaf extends Component {public void add(Component Component){// void implementation} public void remove(Component) Component){// void implementation} public List< component > getChildren(){// void implementation}Copy the code
(4) the Client
Public class Client {public static void main(String[] args) {// Create a root. Root = new Composite(); root.operation(); // create a branch component Composite branch = new Composite(); // create a Leaf node Leaf = new Leaf(); Root. add(branch); branch.add(leaf); } public static void showTree(Component root){for(Component c:root.getChildren()){if(c instanceof Leaf){ // leaf node c.oation (); }else{// showTree(c); }}}}Copy the code
4. The difference between secure mode and transparent mode
-
The security pattern defines only some default behaviors or properties in the abstract component, which is to completely separate the branch node from the leaf node. Transparent mode is to put the methods used for composition into an abstract class, whether the leaf object or the branch object has the same structure, by determining whether it is a leaf node or a branch node, if not handled properly, this can cause problems at runtime, not very recommended.
-
Conflict between safety model and dependency inversion principle; The advantage of transparent mode is that it basically follows the principle of dependency reversal, which facilitates system expansion.
-
Safe mode requires a cast when traversing the tree structure. In transparent mode, it is easier to traverse the entire tree structure without casting.
3. Traversing the family tree of little J through the safe mode
① Abstract component abstract family member class
Public abstract class PersonMode {// private String name; // private String sex; // private int age; public PersonMode(String name, String sex, int age) { this.name = name; this.sex = sex; this.age = age; } // Personal information public String getPersonInfo(){String info=" name :"+name+"\t gender :"+sex+"\t age :"+age; return info; }}Copy the code
② Leaf component
Public class PersonLeaf extends PersonMode {// Write a constructor public PersonLeaf(String name, String sex, int age) { super(name, sex, age); }}Copy the code
③ Branch member
public class PersonBranch extends PersonMode { private List<PersonMode> personModeList=new ArrayList<>(); public PersonBranch(String name, String sex, int age) { super(name, sex, age); } public void addPerson(PersonMode person){ this.personModeList.add(person); } public List<PersonMode> getPersonModeList(){ return this.personModeList; }}Copy the code
(4) the Client
Public class Client {public static void main(String[] args) {/** */ PersonBranch personBranch=getPersonInfo(); showTree(personBranch); } private static PersonBranch getPersonInfo(){private static PersonBranch OneJ=new PersonBranch(" first generation J"," boy ",150); PersonBranch JA=new PersonBranch("JA"," male ",70); PersonBranch JB=new PersonBranch("JB"," male ",60); PersonBranch JC=new PersonBranch("JC"," male ",50); PersonBranch JA1=new PersonBranch("JA1"," male ",40); PersonBranch JA2=new PersonBranch("JA2"," male ",30); PersonBranch JA3=new PersonBranch("JA3"," male ",45); JB1=new PersonBranch("JB1"," male ",40); PersonBranch JB2=new PersonBranch("JB2"," male ",30); //JC's son xiao_J=new PersonBranch("xiao_J"," male ",20); JA1_1=new PersonBranch("JA1_1"," male ",18); PersonBranch JA1_2=new PersonBranch("JA1_2"," male ",16); PersonBranch JA1_3=new PersonBranch("JA1_3"," male ",20); JA3_1=new PersonBranch("JA3_1"," male ",16); PersonBranch JA3_2=new PersonBranch("JA3_2"," male ",20); PersonBranch JA3_3=new PersonBranch("JA3_3"," male ",18); Onej. addPerson(JA); oneJ. addPerson(JA); OneJ.addPerson(JB); OneJ.addPerson(JC); Ja.addperson (JA1); JA.addPerson(JA2); JA.addPerson(JA3); Jb.addperson (JB1); JB.addPerson(JB2); // Assemble JC's son JC. AddPerson (xiao_J); // Assemble JA1's three sons ja1.addPerson (JA1_1); JA1.addPerson(JA1_2); JA1.addPerson(JA1_3); AddPerson (JA3_1); JA3.addPerson(JA3_2); JA3.addPerson(JA3_3); return OneJ; Private static void showTree(PersonBranch root){system.out.println (root.getPersonInfo()); private static void showTree(PersonBranch root){system.out.println (root.getPersonInfo()); For (PersonMode c: root.getPersonModelist ()){if(c instanceof PersonLeaf){// the leaf node system.out.println (c.goetPersoninfo ()); }else{showTree((PersonBranch) c); }}}}Copy the code
The scene class is responsible for establishing the tree structure and traversing the entire tree recursively.
The output is:
Name: First Generation J Gender: Male Age: 150 Name: JA Gender: Male Age: 70 Name: JA1 Gender: Male Age: 40 Name: JA1_1 Gender: Male Age: 18 Name: JA1_2 Gender: Male Age: 16 Name: JA1_3 Gender: Male Age: 20 Name: JA2 Gender: Male Age: 30 Name: JA3 Gender: Male Age: 45 Name: JA3_1 Gender: Male Age: 16 Name: JA3_2 Gender: Male Age: 20 Name: JA3_3 Gender: Male Age: 18 Name: JB Gender: Male Age: 60 Name: JB1 Gender: Male Age: 40 Name: JB2 Gender: Male Age: 30 Name: JC Gender: male age: 50 Name: Xiao_ J Gender: male age: 20Copy the code