类的细粒度和享元模式使用场景

    如果有两份代码,行数差不多,但是一份类的数量是10,另一份类的数量是100,那么相比较第一个类是粗粒度的,第二是细粒度的,也就是说一个类的代码行数相对较多,类比较复杂,就是比较粗粒度的。

   为了类的重用,在设计类时,需要采用细粒度的设计模式,将一个功能复杂的类(代码行数较多)拆分为单一职责的可重用的细粒度的类(代码行数少)。

   在细粒度的类非常多,且非常相似时,可以考虑使用享元模式。

   享元模式可以避免大量非常相似类的开销。在程序设计中,有时需要生成大量细粒度的类实例来表示数据。如果能发现这些实例除了几个参数外基本都是相同的,有时就能够大幅度地减少实例化的类的数量。如果能把那些参数移到类实例的外面,在方法调用时将它们传递进来,就可以通过共享大幅度地减少单个实例的数目。

   使用场景:使用了大量的对象,造成了很大的存储开销;对象的大多数状态可以是外部状态,如果删除对象的外部状态,那么可以用相对较少的共享对象取代很多组对象,可以考虑使用。     -----大话设计模式


版权声明:本文为fly_to_dream原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。