Iterator遍历有多级子集合的集合

来源:互联网 发布:中国十大禁菜 知乎 编辑:程序博客网 时间:2024/06/07 20:23

文章的题目可能有点绕,举一个例子吧,我们想将一个公司的所有员工的姓名打印出来,这个公司的员工分为不同的层级,有公司直接领导的高级员工,也有员工是在公司的 一个子部门工作,还有的员工可能在一个公司的子部门的子部门地下工作(一个部门可能有直接领导的员工,也可能有多个子部门)。。。这个公司的层级结构可能达到7 8 级.请问如何实现这个需求。


先来看看代码实现吧

1 首先新建一个 部门和员工都要实现的公共接口

public interface Person {void getPersonInfo();}

2 新建员工类和部门类

public class Employee implements Person {/** * 员工姓名 */private String name;/** * 部门名称 */private String company;public Employee(String name,String company){this.name = name;this.company = company;}@Overridepublic void getPersonInfo() {System.out.println("部门:"+this.company+",姓名:"+this.name);}}public class Department implements Person{//这个公司类确实是要实现Person接口,不是我写错了ArrayList list = new ArrayList(256);/** * 将员工或者子部门加入本部门 */public void addPerson(Person person){list.add(person);}@Overridepublic void getPersonInfo() {Iterator iterator = list.iterator();while(iterator.hasNext()){ //下面这段代码体现了Department类实现Person接口的价值,你可以DEBUGGER跟一下代码Person person = (Person) iterator.next();person.getPersonInfo();}}}

3 新建测试类

public class Test {public static void main(String... strings){//公司现在有7个人Person person1 = new Employee("员工1", "总公司");Person person2 = new Employee("员工2", "总公司");Person person3 = new Employee("员工3", "一级部门");Person person4 = new Employee("员工4", "一级部门");Person person5 = new Employee("员工5", "一级部门");Person person6 = new Employee("员工6", "二级部门");Person person7 = new Employee("员工7", "二级部门");//Department company = new Department(); //公司Department department1 = new Department();//一级部门Department department2 = new Department();//二级部门//将对应的人员放进对应的部门department2.addPerson(person7);department2.addPerson(person6);department1.addPerson(person5);department1.addPerson(person4);department1.addPerson(person3);company.addPerson(person2);company.addPerson(person1);department1.addPerson(department2);company.addPerson(department1);company.getPersonInfo();}}

输出结果:

部门:总公司,姓名:员工2
部门:总公司,姓名:员工1
部门:一级部门,姓名:员工5
部门:一级部门,姓名:员工4
部门:一级部门,姓名:员工3
部门:二级部门,姓名:员工7
部门:二级部门,姓名:员工6


原创粉丝点击