`

动态解耦 静态解耦

 
阅读更多

1.静态解耦:
    先解释下我理解的静态耦合,指的是编译期依赖关系已经确定,在运行时环境中,代码间的依赖关系不能改变。例如,我们在开发中经常会说的“把代码写死了”。静态是相对动态的、运行时的、可配置的和插件式的。
    那么在静态环境中,如何解耦?主要是依赖接口。下面举两个小例子简单说明下:
    EX1: 假设一个人不知道接口的意义,那么他写出两个类的依赖关系一般如下:

Java代码  收藏代码
  1. public   class  ClassA {  
  2.     public   void  invoke() {  
  3.     [color=blue]ClassB b = new  ClassB();  
  4.     b.action();[/color]         //do some other things   
  5.     }  
  6. }  
  7.   
  8. public   class  ClassB {  
  9.     public   void  action() {  
  10.     //do something   
  11.     }  
  12. }  


   我们常常说的“耦合”,我认为一个重要的因素就是环境的变,如果没有变化的环境,那么多么的“耦合”也是无所谓的;假如现在变化来了,ClassA中的 invoke()方法不符合现在的需求了,而且需要改变的部分恰好是invoke()中的前两行,也正是和ClassB耦合的那部分,而ClassB的 action方法还在别的代码有调用。现在如果更改,则必须修改invoke()的前两行代码。这个是面向对象中非常忌讳的。所谓代码应该对扩展开放,对修改封闭 ,那么我们用“面向接口编程”的思想对他进行一下改造吧。

Java代码  收藏代码
  1. public   class  ClassA {  
  2.     public   void  invoke() {  
  3.     Interface i = Factory.newInstance().produce(1 );  
  4.     i.action();  
  5.     }  
  6. }  
  7. public   class  Factory {  
  8.     private   static  Factory f =  new  Factory();  
  9.       
  10.     public   static  Factory newInstance() {  
  11.     return  f;  
  12.     }  
  13.       
  14.     public  Interface produce( int  k) {  
  15.     if (k ==  0 ) {  
  16.         return   new  Imp1(); //接口的实现类1   
  17.     } else   if  (k ==  1 ){  
  18.         return   new  Imp2(); //接口的实现类2   
  19.     }//other implements   
  20.           
  21.     return   new  DefautImpl();  
  22.     }  
  23. }  


   现在的情况稍好一点了,至少我们把变化集中管理在了一个工厂类中,但是,如果有变化,我们还是要深入代码去修改这个工厂类,依赖关系仍旧局限于编译期;
    难道没有解决办法了吗?当然有,那就是我理解的动态解耦。

2.动态解耦
    所谓动态是对象之间的依赖关系不依赖于编译期,运行时动态确定。动态解耦与插件式,可配置具有某种意思的巧合。套用某句话,正是因为有了动态解耦技术,代码间的依赖关系才真正解脱了。  
    动态解耦所用的技术主要是反射机制并结合配置文件。下面是一个例子,仅仅演示什么是动态的(很粗糙的。。)

Java代码  收藏代码
  1. public   class  Main {  
  2.   
  3.     /**  
  4.      * @param args  
  5.      */   
  6.     public   static   void  main(String[] args) {  
  7.         BufferedReader reader = new  BufferedReader( new      InputStreamReader(System.in));  
  8.           
  9.         while ( true ) {  
  10.             String instruction = null ;  
  11.             try  {  
  12.                 instruction = reader.readLine();  
  13.             } catch  (IOException e) {  
  14.                 e.printStackTrace();  
  15.                 System.exit(-1 );  
  16.             }  
  17.               
  18.             if ( "exit" .equalsIgnoreCase(instruction)) {  
  19.                 break ;  
  20.             }  
  21.               
  22.             if ( "invoke" .equalsIgnoreCase(instruction)) {  
  23.                 //一个类和被调用类直接耦合在一起   
  24.                 Interface inter = loadFromCfgFile();  
  25.                 if (inter ==  null continue ;  
  26.                   
  27.                 inter.say("just say" );  
  28.             }  
  29.         }  
  30.   
  31.     }  
  32.   
  33.     private   static  Interface loadFromCfgFile() {  
  34.         InputStream in = MainClass.class .getResourceAsStream( "test.properties" );  
  35.         Properties p = new  Properties();  
  36.         try  {  
  37.             p.load(in);  
  38.         } catch  (IOException e) {  
  39.             e.printStackTrace();  
  40.             return   null ;  
  41.         }  
  42.           
  43.         String className = p.getProperty("class" );  
  44.         System.out.println("class name loaded from config file is: "  + className);  
  45.           
  46.         Object object = loadClassAccordingClassName(className);  
  47.         if (object ==  null return   null ;  
  48.           
  49.           
  50.         return  (Interface) object;  
  51.     }  
  52.   
  53.     private   static  Object loadClassAccordingClassName(String className) {  
  54.         Class<?> clazz = null ;  
  55.         try  {  
  56.             clazz = Class.forName(className);  
  57.         } catch  (ClassNotFoundException e) {  
  58.             System.out.println("can not find the class." );  
  59.         }  
  60.         if (clazz ==  null return   null ;  
  61.           
  62.         Object object = null ;  
  63.         try  {  
  64.             object = clazz.newInstance();  
  65.         } catch  (InstantiationException e) {  
  66.             System.out.println("can not instance the class." );  
  67.             e.printStackTrace();  
  68.         } catch  (IllegalAccessException e) {  
  69.             System.out.println("can not instance the class...." );  
  70.             e.printStackTrace();  
  71.         }  
  72.         return  object;  
  73.     }  
  74.   
  75. }  



实现类代码:

Java代码  收藏代码
  1. public   class  ImplementClass  implements  Interface{  
  2.   
  3.     public   void  say(String str) {  
  4.         System.out.println("say "  + str);  
  5.                   //System.out.println("added later.");//   
  6.   
  7.     }  
  8.   
  9. }  



配置文件代码:

Java代码  收藏代码
  1. class =ImplementClass  



    你可以简单的修改ImplementClass.java的代码,加上注释掉的语句,编译后,就会发现输出和以前不同了。
    如上所示,代码间的依赖关系,从源代码中移动到了配置文件中,并利用反射技术来动态确定其依赖关系;好处就是依赖集中管理、符合开放封闭原则;
    对配置文件的修改产生的变化,还有一种更优雅的方式,可以启动一个守护线程对其进行定期检查,如变化,可重新加载并实例化,这个以后再续;

分享到:
评论

相关推荐

    感应电动机的解耦控制与矢量控制的解耦性质

    对感应电动机的解耦控制及...研究结果表明,感应电动机的矢量控制只能实现电机转速与转子磁链之间的静态解耦,不 能实现二者之间的动态解耦,而基于状态反馈线性化的解耦控制方法,能够实现转速与转子磁链之 间的动态解耦

    同步电动机三自由度内模动态解耦控制 (2010年)

    为了解决矢量控制只能实现电机转矩与磁链的静态解耦,不能实现两者的动态解耦的问题,探讨了多自由度内模解耦方案。由于一自由度内模解耦,当电机参数非同步变化时,电机定子电压方程仍存在耦合现象;而二自由度内模...

    无陀螺惯性测量组合静动态解耦方法 (2007年)

    无陀螺惯性测量技术是利用加...该方法克服了静态解耦和动态解耦分别进行带来的处理复杂性,简化了后续处理系统.最后进行了系统3个方向角速度运算的仿真验证,结果表明,系统经静动态解耦后导航精度得到了有效提高.

    matlab开发-静态空间系统的输入解耦零可滚动特征值

    matlab开发-静态空间系统的输入解耦零可滚动特征值。函数计算输入去耦零点,即系统的不可控特征值。

    矿井提升钢丝绳应变式张力传感器解耦研究

    为了克服这一难题,结合大载荷低高度的传感器安装条件和结构特点,进行了实验研究,采用最小二乘法和独立成分法对比分析了传感器纵向受力工况下静态解耦效果,结果表明,Z方向与X,Y方向和MZ的静态解耦耦合率值均较小,独立...

    无轴承异步电机的非线性动态解耦控制

    针对无轴承异步电机多变量、非线性、强耦合的特点,提出一种基于支持向量机α阶逆...仿真和实验研究表明,支持向量机α阶逆系统方法能够实现无轴承异步电机悬浮力和旋转力之间的动态解耦,控制系统具有良好的动静态性能。

    基于逆系统理论感应电机转矩和磁链解耦控制

    针对感应电机数学模型的非线性、强耦合特性,应用逆系统理论,将感应电机转矩与定子磁链动态解耦成2个一阶线性子系统,证明感应电机数学模型的可逆性。设计了基于逆系统方法的感应电机闭环控制系统。仿真结果表明这种...

    最小几何变形解耦方法中BTZ真空的一般内部各向异性解决方案

    在这项工作中,我们实施了最小几何变形解耦方法,以从最普通的各向同性溶液中,在包括宇宙常数$$ \ varLambda $$Λ的$$ 2 + 1 $$ 2 + 1维中,获得BTZ真空的常规静态内部溶液。 我们得到一般解只能通过原始各向同性...

    多变量信号解耦控制系统设计研究 (2012年)

    结论信号解耦方法表明解耦器的存在性、可实现性和稳定性取决于耦合系统的结构及参数,重新匹配变量、部分解耦和静态解耦是其改变办法。信号解耦器设计方法简单有效,但多变量信号解耦器的连接比较复杂。

    重力解耦的各向异性解

    我们研究了静态自重力系统各向同性内部解的扩展,以通过通过最小几何变形方法实现的重力解耦来包括各向异性球对称重力源的影响。 特别是,详细研究了恒星表面与外部Schwarzschild时空的匹配条件,并且我们描述了如何...

    放卷张力系统解耦控制器的设计

    根据放卷系统的工作机理,建立了放卷张力系统的非线性耦合数学模型,用ADRC方法推导了张力系统的解耦模型,得到了系统阶数和静态解耦模型.在放卷张力系统模型的基础上,利用ADRC技术对放卷系统的张力解耦...

    three.zip_三相解耦_二阶+切换_平滑控制_控制系统 MATLAB_逆变器

    采用新的解耦方法,依据独立和并网模式控制系统超调量越小,模式切换过程中被控量的波动越小。切换过程就越平滑的原则。完成了两种模式的控制器设计,即分别应用积分环节、比例环节即可将独立模式和并网模式整定成...

    基于最小二乘支持向量机的无轴承同步磁阻电机解耦控制

    无轴承同步磁阻电机是一个复杂的多变量、强耦合非线性系统, 实现其非线性动态解耦控制是无轴承同步 磁阻电机稳定运行的前提.... 仿真结果表明该方法实现了系统的动态解耦, 并且具有良好的动、静态特性.&lt;/p&gt;

    基于单神经元PID的永磁同步电机解耦控制.pdf

    永磁同步电机(PMSM)数学模型可简化为一个两输入两输出的非线性系统。神经网络具有逼近任意复杂非线性系统的能力,将经典比例一...仿真和实验结果表明该系统模型响应速度快,稳定性强,动、静态性能良好,鲁棒性很好。

    各向同性和重力解耦引起的复杂性变化

    我们对静态和球对称系统采用重力解耦方法来开发一种简单而有效的方法,以便(a)连续各向同性地爱因斯坦场方程的各向异性解,以及(b)生成新的自重力分布的解。 相同或消失的复杂度因子。 出于说明目的给出了一些...

    bishegonglvqiankui.rar_功率控制_并网逆变器_直接功率 逆变_级联_逆变器解耦

    级联多电平并网逆变器直接功率控制,有功武功可以实现解耦控制,动态和静态性能良好。

    袋式除尘器风量风压解耦控制模型及仿真

    研究了一种袋式除尘器适用的控制模型,运用前馈补偿法设计了控制回路的解耦补偿器,仿真结果表明,解耦控制使得系统具有良好的动态和静态性能。

    六维力传感器静态解耦方法 (2012年)

    在系统分析六维力传感器线性解耦基本原理的基础上,依据各向同性指标比较分析了基于克拉默法则和最小二乘法线性解耦算法的优劣,建立了RBF神经网络非线性解耦模型。研究结果表明:与克拉默法则相比,最小二乘法得到...

    六维力传感器静态解耦算法及静态标定的研究* (2013年)

    耦合误差严重影响着六维力传感器的精度,标定试验的准确性对提高六维力传感器的精度也是必不可少的。针对传感器输出电压正负方向拟合函数不同...通过标定数据验证了基于耦合误差和分段拟合的静态解耦算法性能的优越性。

Global site tag (gtag.js) - Google Analytics