设计模式之享元模式

享元模式(Flyweight),运用共享技术有效地支持大量细粒度的对象。

也就是说,在一个系统中如果有多个相同的对象,那么只共享一份就可以了,不必每个都去实例化一个对象。

比如说一个文本系统,每个字母定一个对象,那么大小写字母一共就是52个,那么就要定义52个对象。如果有一个1M的文本,那么字母是何其的多,如果每个字母都定义一个对象那么内存早就爆了。那么如果要是每个字母都共享一个对象,那么久大大节约了资源。


Flyweight类,它是所有具体享元类的父类或接口,通过这个接口,Flyweight可以接受并作用于外部状态。

public abstract class Flyweight {

    public abstract void operation();
}

ConcreteFlyweight是继承Flyweight父类或实现Flyweight接口,并为内部状态增加存储空间。

public class ConcreteFlyweight extends Flyweight {

    private String mStr;
    public ConcreteFlyweight(String str) {
        mStr = str;
    }

    @Override
    public void operation() {
        System.out.println("具体享元: " + mStr);
    }

}

UnsharedConcreteFlyweight是指那些不需要共享的Flyweight子类。因为Flyweight接口共享成为可能,但它并不强制共享。

public class UnsharedConcreteFlyweight extends Flyweight {

    private String mStr;

    public UnsharedConcreteFlyweight(String str) {
        mStr = str;
    }

    @Override
    public void operation() {
        System.out.println("不共享的Flyweight: " + mStr);
    }

}

FlyweightFactory,是一个享元工厂,用来创建并管理Flyweight对象。它主要是用来确保合理地共享Flyweight,当用户请求一个Flyweight时,FlyweightFactory对象提供一个已创建的实例或者创建一个(如果不存在的话)。

public class FlyweightFactory {

    private HashMap<String, Flyweight> mFlyweights = new HashMap<String, Flyweight>();

    public Flyweight getFlyweight(String key) {
        if (!mFlyweights.containsKey(key)) {
            mFlyweights.put(key, new ConcreteFlyweight(key));
        }
        return mFlyweights.get(key);
    }

    public int getFlyweigtCount() {
        int count = mFlyweights.size();
        System.out.println("享元个数:" + count);
        return count;
    }
}

调用:

FlyweightFactory factory = new FlyweightFactory();
Flyweight fa = factory.getFlyweight("google");
fa.operation();

Flyweight fb = factory.getFlyweight("google");
fb.operation();

Flyweight fc = factory.getFlyweight("apple");
fc.operation();

Flyweight fd = factory.getFlyweight("google");
fd.operation();

UnsharedConcreteFlyweight uf = new UnsharedConcreteFlyweight("banana");
uf.operation();

factory.getFlyweigtCount();

输出结果:

具体享元: google
具体享元: google
具体享元: apple
具体享元: google
不共享的Flyweight: banana
享元个数:2

在享元对象内部并且不会随环境改变而改变的共享部分,可以称为是享元对象的内部状态;

随环境改变而改变的、不可以共享的状态就是外部状态。

享元模式可以避免大量非常相似类的开销。在程序设计中,有时需要生成大量细粒度的类实例来表示数据。

如果能发现这些实例除了几个参数基本上都是相同的,有时就能够大幅度地减少需要实例化的类的数量。

如果能把那些参数移到类实例的外面,在方法调用时将它们传递进来,就可以通过共享大幅度地减少单个实例的数目。

如果一个应用程序使用了大量的对象,而大量的这些对象造成了很大的存储开销时就应该考虑使用;

还有就是对象的大多数状态可以是外部状态,如果删除对象的外部状态,那么可以用相对较少的共享对象取代很多组对象,此时可以考虑使用享元模式。

在Java语音中,String类型就是使用了享元模式。String对象是final类型,对象一旦创建就不可改变。在Java中字符串常量都是存在常量池中,Java会确保一个字符串常量在常量池中只有一个拷贝。经典例子如:

String s1 = "hello";
String s2= "hello";
System.out.println("s1和s2是同一个对象吗:" + s1.equals(s2));

输出结果是:true。
基于径向基函数神经网络RBFNN的自适应滑模控制学习(Matlab代码实现)内容概要:本文介绍了基于径向基函数神经网络(RBFNN)的自适应滑模控制方法,并提供了相应的Matlab代码实现。该方法结合了RBF神经网络的非线性逼近能力和滑模控制的强鲁棒性,用于解决复杂系统的控制问题,尤其适用于存在不确定性和外部干扰的动态系统。文中详细阐述了控制算法的设计思路、RBFNN的结构与权重更新机制、滑模面的构建以及自适应律的推导过程,并通过Matlab仿真验证了所提方法的有效性和稳定性。此外,文档还列举了大量相关的科研方向和技术应用,涵盖智能优化算法、机器学习、电力系统、路径规划等多个领域,展示了该技术的广泛应用前景。; 适合人群:具备一定自动控制理论基础和Matlab编程能力的研究生、科研人员及工程技术人员,特别是从事智能控制、非线性系统控制及相关领域的研究人员; 使用场景及目标:①学习和掌握RBF神经网络与滑模控制相结合的自适应控制策略设计方法;②应用于电机控制、机器人轨迹跟踪、电力电子系统等存在模型不确定性或外界扰动的实际控制系统中,提升控制精度与鲁棒性; 阅读建议:建议读者结合提供的Matlab代码进行仿真实践,深入理解算法实现细节,同时可参考文中提及的相关技术方向拓展研究思路,注重理论分析与仿真验证相结合。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值