里氏替换原则(Liskov Substitution Principle, LSP)
里氏替换原则(Liskov Substitution Principle,LSP) 子类型必须能够替换它们的父类型。 分析: 代码示例: 父类:
package com.test.principle.lsp; public class SuperLiskov { public int a = 1; public void a1() { } public void a2() { } } 子类:
package com.test.principle.lsp; public class SubLiskov extends SuperLiskov { public int b; public int a = 2; public void a1() { } public void a3() { } } 测试代码:
package com.test.principle.lsp; public class LiskovClient { public static void main(String[] args) { SuperLiskov sk = new SuperLiskov(); sk = new SubLiskov(); sk.a1(); sk.a2(); System.out.println(sk.a); } } 输出结果为:1 里氏替换原则和struts struts 的ActionMessageStruts具备消息传递功能,ActionMessage的容器包括:“ActionErrors”和“Actionmessages”,后者的实例均可以相互设置为容器。 并且ActionErrors也可以运用error.add(msgs)使自己成为ActionMessages的容器。此处较好的实现了里氏替换原则的原理。即这种做法实现了在父类涉及的场所 子类均可安全替换。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |