装饰设计模式
- 装饰设计模式的好处是:
-
耦合性不强,被装饰的类的变化与装饰类的变化无关
interface Coder { public void code(); } class Student implements Coder { @Override public void code() { System.out.println("javase"); System.out.println("javaweb"); } } class HeiMaStudent implements Coder { private Student s; //获取到被包装的类的引用 public ItcastStudent(Student s) { //通过构造函数创建对象的时候,传入被包装的对象 this.s = s; } @Override public void code() { //对其原有功能进行升级 s.code(); System.out.println("数据库"); System.out.println("ssh"); System.out.println("安卓"); System.out.println("....."); } }
-
package com.heima.chario;
public class Demo06_Wrapper {
/**
* @param args
* 装饰设计模式的好处是:
* 耦合性不强,被装饰的类的变化与装饰类的变化无关
*/
public static void main(String[] args) {
HeiMaStudent hsm = new HeiMaStudent(new Student());
hsm.code();
}
}
interface Coder {
public void code();
}
class Student implements Coder {
@Override
public void code() {
System.out.println("java");
System.out.println("javaee");
}
}
class HeiMaStudent implements Coder {
//1.获取被装饰类的引用
private Student s; //获取学生引用
//2.在构造方法中传入被装饰类的对象
public HeiMaStudent(Student s) {
this.s = s;
}
//3.对原有的功能进行升级
@Override
public void code() {
s.code();
System.out.println("ssh");
System.out.println("数据库");
System.out.println("大数据");
System.out.println("......");
}
}
装饰设计模式详解
本文深入探讨了装饰设计模式,解析其如何在不增加类数量的情况下为对象动态添加职责,实现功能增强而保持低耦合性。通过具体示例,展示了装饰者模式在代码中的应用,及其如何与被装饰类解耦,实现灵活的功能升级。
1858

被折叠的 条评论
为什么被折叠?



