打字猴:1.700462673e+09
1700462673 }
1700462674
1700462675 public ConcreteColleague2 getC2(){
1700462676
1700462677 return c2;
1700462678
1700462679 }
1700462680
1700462681 public void setC2(ConcreteColleague2 c2){
1700462682
1700462683 this.c2=c2;
1700462684
1700462685 }
1700462686
1700462687 //中介者模式的业务逻辑
1700462688
1700462689 public abstract void doSomething1();
1700462690
1700462691 public abstract void doSomething2();
1700462692
1700462693 }
1700462694
1700462695 在Mediator抽象类中我们只定义了同事类的注入,为什么使用同事实现类注入而不使用抽象类注入呢?那是因为同事类虽然有抽象,但是没有每个同事类必须要完成的业务方法,当然如果每个同事类都有相同的方法,比如execute、handler等,那当然注入抽象类,做到依赖倒置。
1700462696
1700462697 具体的中介者一般只有一个,即通用中介者,其源代码如代码清单14-13所示。
1700462698
1700462699 代码清单14-13 通用中介者
1700462700
1700462701 public class ConcreteMediator extends Mediator{
1700462702
1700462703 @Override
1700462704
1700462705 public void doSomething1(){
1700462706
1700462707 //调用同事类的方法,只要是public方法都可以调用
1700462708
1700462709 super.c1.selfMethod1();
1700462710
1700462711 super.c2.selfMethod2();
1700462712
1700462713 }
1700462714
1700462715 public void doSomething2(){
1700462716
1700462717 super.c1.selfMethod1();
1700462718
1700462719 super.c2.selfMethod2();
1700462720
1700462721 }
1700462722
[ 上一页 ]  [ :1.700462673e+09 ]  [ 下一页 ]