《JAVA设计模式》之享元模式(Flyweight)

时间:2024-12-10 15:34:20

在阎宏博士的《JAVA与模式》一书中开头是这样描述享元(Flyweight)模式的:

  Flyweight在拳击比赛中指最轻量级,即“蝇量级”或“雨量级”,这里选择使用“享元模式”的意译,是因为这样更能反映模式的用意。享元模式是对象的结构模式。享元模式以共享的方式高效地支持大量的细粒度对象。


Java中的String类型

  在JAVA语言中,String类型就是使用了享元模式。String对象是final类型,对象一旦创建就不可改变。在JAVA中字符串常量都是存在常量池中的,JAVA会确保一个字符串常量在常量池中只有一个拷贝。String a="abc",其中"abc"就是一个字符串常量。

public class Test {

    public static void main(String[] args) {

        String a = "abc";
String b = "abc";
System.out.println(a==b); }
}

  上面的例子中结果为:true ,这就说明a和b两个引用都指向了常量池中的同一个字符串常量"abc"。这样的设计避免了在创建N多相同对象时所产生的不必要的大量的资源消耗。

享元模式的结构

  享元模式采用一个共享来避免大量拥有相同内容对象的开销。这种开销最常见、最直观的就是内存的损耗。享元对象能做到共享的关键是区分内蕴状态(Internal State)外蕴状态(External State)。

  一个内蕴状态是存储在享元对象内部的,并且是不会随环境的改变而有所不同。因此,一个享元可以具有内蕴状态并可以共享。

  一个外蕴状态是随环境的改变而改变的、不可以共享的。享元对象的外蕴状态必须由客户端保存,并在享元对象被创建之后,在需要使用的时候再传入到享元对象内部。外蕴状态不可以影响享元对象的内蕴状态,它们是相互独立的。

  享元模式可以分成单纯享元模式复合享元模式两种形式。

单纯享元模式  

  在单纯的享元模式中,所有的享元对象都是可以共享的。

《JAVA设计模式》之享元模式(Flyweight)

  单纯享元模式所涉及到的角色如下:

  ●  抽象享元(Flyweight)角色 :给出一个抽象接口,以规定出所有具体享元角色需要实现的方法。

  ●  具体享元(ConcreteFlyweight)角色:实现抽象享元角色所规定出的接口。如果有内蕴状态的话,必须负责为内蕴状态提供存储空间。

  ●  享元工厂(FlyweightFactory)角色 :本角色负责创建和管理享元角色。本角色必须保证享元对象可以被系统适当地共享。当一个客户端对象调用一个享元对象的时候,享元工厂角色会检查系统中是否已经有一个符合要求的享元对象。如果已经有了,享元工厂角色就应当提供这个已有的享元对象;如果系统中没有一个适当的享元对象的话,享元工厂角色就应当创建一个合适的享元对象。

源代码

  抽象享元角色类

public interface Flyweight {
//一个示意性方法,参数state是外蕴状态
public void operation(String state);
}

  具体享元角色类ConcreteFlyweight有一个内蕴状态,在本例中一个Character类型的intrinsicState属性代表,它的值应当在享元对象被创建时赋予。所有的内蕴状态在对象创建之后,就不会再改变了。

  如果一个享元对象有外蕴状态的话,所有的外部状态都必须存储在客户端,在使用享元对象时,再由客户端传入享元对象。这里只有一个外蕴状态,operation()方法的参数state就是由外部传入的外蕴状态。

public class ConcreteFlyweight implements Flyweight {
private Character intrinsicState = null;
/**
* 构造函数,内蕴状态作为参数传入
* @param state
*/
public ConcreteFlyweight(Character state){
this.intrinsicState = state;
} /**
* 外蕴状态作为参数传入方法中,改变方法的行为,
* 但是并不改变对象的内蕴状态。
*/
@Override
public void operation(String state) {
// TODO Auto-generated method stub
System.out.println("Intrinsic State = " + this.intrinsicState);
System.out.println("Extrinsic State = " + state);
} }

  享元工厂角色类,必须指出的是,客户端不可以直接将具体享元类实例化,而必须通过一个工厂对象,利用一个factory()方法得到享元对象。一般而言,享元工厂对象在整个系统中只有一个,因此也可以使用单例模式。

  当客户端需要单纯享元对象的时候,需要调用享元工厂的factory()方法,并传入所需的单纯享元对象的内蕴状态,由工厂方法产生所需要的享元对象。

public class FlyweightFactory {
private Map<Character,Flyweight> files = new HashMap<Character,Flyweight>(); public Flyweight factory(Character state){
//先从缓存中查找对象
Flyweight fly = files.get(state);
if(fly == null){
//如果对象不存在则创建一个新的Flyweight对象
fly = new ConcreteFlyweight(state);
//把这个新的Flyweight对象添加到缓存中
files.put(state, fly);
}
return fly;
}
}

  客户端类

public class Client {

    public static void main(String[] args) {
// TODO Auto-generated method stub
FlyweightFactory factory = new FlyweightFactory();
Flyweight fly = factory.factory(new Character('a'));
fly.operation("First Call"); fly = factory.factory(new Character('b'));
fly.operation("Second Call"); fly = factory.factory(new Character('a'));
fly.operation("Third Call");
} }

  虽然客户端申请了三个享元对象,但是实际创建的享元对象只有两个,这就是共享的含义。运行结果如下:

aaarticlea/png;base64,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" alt="" />

复合享元模式

  在单纯享元模式中,所有的享元对象都是单纯享元对象,也就是说都是可以直接共享的。还有一种较为复杂的情况,将一些单纯享元使用合成模式加以复合,形成复合享元对象。这样的复合享元对象本身不能共享,但是它们可以分解成单纯享元对象,而后者则可以共享。

  《JAVA设计模式》之享元模式(Flyweight)

  复合享元角色所涉及到的角色如下:

  ●  抽象享元(Flyweight)角色 :给出一个抽象接口,以规定出所有具体享元角色需要实现的方法。

  ●  具体享元(ConcreteFlyweight)角色:实现抽象享元角色所规定出的接口。如果有内蕴状态的话,必须负责为内蕴状态提供存储空间。

  ●   复合享元(ConcreteCompositeFlyweight)角色 :复合享元角色所代表的对象是不可以共享的,但是一个复合享元对象可以分解成为多个本身是单纯享元对象的组合。复合享元角色又称作不可共享的享元对象。

  ●   享元工厂(FlyweightFactory)角色 :本角 色负责创建和管理享元角色。本角色必须保证享元对象可以被系统适当地共享。当一个客户端对象调用一个享元对象的时候,享元工厂角色会检查系统中是否已经有 一个符合要求的享元对象。如果已经有了,享元工厂角色就应当提供这个已有的享元对象;如果系统中没有一个适当的享元对象的话,享元工厂角色就应当创建一个 合适的享元对象。

源代码

  抽象享元角色类

public interface Flyweight {
//一个示意性方法,参数state是外蕴状态
public void operation(String state);
}

  具体享元角色类

public class ConcreteFlyweight implements Flyweight {
private Character intrinsicState = null;
/**
* 构造函数,内蕴状态作为参数传入
* @param state
*/
public ConcreteFlyweight(Character state){
this.intrinsicState = state;
} /**
* 外蕴状态作为参数传入方法中,改变方法的行为,
* 但是并不改变对象的内蕴状态。
*/
@Override
public void operation(String state) {
// TODO Auto-generated method stub
System.out.println("Intrinsic State = " + this.intrinsicState);
System.out.println("Extrinsic State = " + state);
} }

  复合享元对象是由单纯享元对象通过复合而成的,因此它提供了add()这样的聚集管理方法。由于一个复合享元对象具有不同的聚集元素,这些聚集元素在复合享元对象被创建之后加入,这本身就意味着复合享元对象的状态是会改变的,因此复合享元对象是不能共享的。

  复合享元角色实现了抽象享元角色所规定的接口,也就是operation()方法,这个方法有一个参数,代表复合享元对象的外蕴状态。一个复合享元对象的所有单纯享元对象元素的外蕴状态都是与复合享元对象的外蕴状态相等的;而一个复合享元对象所含有的单纯享元对象的内蕴状态一般是不相等的,不然就没有使用价值了。

public class ConcreteCompositeFlyweight implements Flyweight {

    private Map<Character,Flyweight> files = new HashMap<Character,Flyweight>();
/**
* 增加一个新的单纯享元对象到聚集中
*/
public void add(Character key , Flyweight fly){
files.put(key,fly);
}
/**
* 外蕴状态作为参数传入到方法中
*/
@Override
public void operation(String state) {
Flyweight fly = null;
for(Object o : files.keySet()){
fly = files.get(o);
fly.operation(state);
} } }

  享元工厂角色提供两种不同的方法,一种用于提供单纯享元对象,另一种用于提供复合享元对象。

public class FlyweightFactory {
private Map<Character,Flyweight> files = new HashMap<Character,Flyweight>();
/**
* 复合享元工厂方法
*/
public Flyweight factory(List<Character> compositeState){
ConcreteCompositeFlyweight compositeFly = new ConcreteCompositeFlyweight(); for(Character state : compositeState){
compositeFly.add(state,this.factory(state));
} return compositeFly;
}
/**
* 单纯享元工厂方法
*/
public Flyweight factory(Character state){
//先从缓存中查找对象
Flyweight fly = files.get(state);
if(fly == null){
//如果对象不存在则创建一个新的Flyweight对象
fly = new ConcreteFlyweight(state);
//把这个新的Flyweight对象添加到缓存中
files.put(state, fly);
}
return fly;
}
}

  客户端角色

public class Client {

    public static void main(String[] args) {
List<Character> compositeState = new ArrayList<Character>();
compositeState.add('a');
compositeState.add('b');
compositeState.add('c');
compositeState.add('a');
compositeState.add('b'); FlyweightFactory flyFactory = new FlyweightFactory();
Flyweight compositeFly1 = flyFactory.factory(compositeState);
Flyweight compositeFly2 = flyFactory.factory(compositeState);
compositeFly1.operation("Composite Call"); System.out.println("---------------------------------");
System.out.println("复合享元模式是否可以共享对象:" + (compositeFly1 == compositeFly2)); Character state = 'a';
Flyweight fly1 = flyFactory.factory(state);
Flyweight fly2 = flyFactory.factory(state);
System.out.println("单纯享元模式是否可以共享对象:" + (fly1 == fly2));
}
}

运行结果如下:

aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAA4sAAADxCAIAAADtILUOAAAgAElEQVR4nO3da3Ac1YEv8PmcvTdftmq3KrVVqa1s7RKoSi3LiptMskndulnuZbeWQCLCIwEmxhlkIMbIYJRgsLBBksGxB3uxBQZbJmANEoplGzd+YCyw/OIhy9giBoHfBluy5Laeo3n1/dAzPeecPuf06Z6eUUv6/2oK5J7Tp8853dPzn9PzCOm0np6epqampqYmfeaZ9h2f9h30xjrmjZmkKa+np2ey98DkwMMBACAIRE9GIfIf5lN1GVsVINO+49O+g96Yx/xkx8XJNMOjKh4XAH5paWmZM2dOpXtz5sxpaWnxsRKYiuxPQ4WEing6jU37DnpjHvNZyGaz2eyMzal4dMBU8fTTT4+Ojk52K/ji8fisWbOWL1/+snvLly+/44474vG4L5WY7QnyWIEI8xyUS6hMPG1qjDTFbm9qjDQ1VjU11cSbGuLxxnh7PN6+Pb69o72ju73jeLkbXjLT/vmJ7OCWZ/+Ze5u81k0axFMuhFSAkorFGuJx9niLx5tisQbHdeWp68C2h7m3YluspqqqKhaLbdy48S333n777eXLl1dVVflSicpYQWCRz0GChBq7vVtPGIZxIZEgb4Zh7OrsMf9u7zg1CW0vgWn/5ER2cFPDtRPJNHM7tmXODAyp5jGfIdy5aNN3H+qU3+5ctCkz3ZV2MvX1H8YeumlLbNaOxujJ3YtKsgn3pv1JAAIiFmuIxWJMSDXjqblcvrpjQuWe3t2G1OaXqxRv5FqVlZUbNmzYvn37IVrlsm7H20cffXTo0CHzYn3xlaiMlY+a1JShJaSda/6xFNXOkfJlLU5CZYavMRYxE+rpI4d7li758JYbe5YuOX3ksGEYuzqPXUgkLk6XkDrtn5mYDr5Z/y/2U9jnuxf2zLCQasbTNO27c9+vnL1Efvvu3PfTM0NJQurrP7y46baUvjWlb+3s2LujMepz/UWY9qcC8EtNTU1jYyOzsLGxsaamxnHdWKzh+PHjx48fNyNpe3u7GUythe3t7ZLV5alr39b54xOpxEQ6MZHK/5E7ve97a75a53Rd11976f7DAynurfnlKvJvcq3Kyso33nhj7969RwhtbW9WLuv+7Epacqtc1n306NFPPvnETKjFV6IyVo5CL/y4Yu3tf/rgKceSAUyoO9f8YzZzuRQhdc6cOaKPNMgTqqu1rOHiJ9RYQ6RbT2QNo2fp0+cfvG940cLzD97Xs/TpjJHdtffYxYlE38RECRJqV11FKNJqX94a4S72g/y4Wbr5k3BN23X3N4Zr2iKr92796ExpWiHVGglV1HV5XZvpYLzuuvGJtHm7atbq8Yl0YiJ16uCKz3cvPLal6o1nriu+vWK+7seuuooixoWfUB9897b76kSn5sMDqdvuq/vug+9OSl4kbJ0dmr3V5TrWq1XHhSSfQ2o+nt74uw3Jiy3jJ9dtic3yrXIlsscSEuq01+FEpZKampra2lompJrx1FwuXz0eb2poqDXzaGNjY0NDbWNjo/nPhoZa+9V/hjx1vbflkdFE6qU3P1y1cf+y9e/XvfTuWKJwen9/86MqHdR1vanxwcMDqXMDCfvthdijhwdS/zn31Z0HTr4QoyqsrKxsa2s7ePDgX/JOnTqxZctmM1xeGU2JbpXLus3yZkKVVPLej2748sVXroymvnzxlfd+dIOoEpWxchSqvr5au/GJbbc4hlTHAFqKhPrTBS03PNb6/37/5g2Pxn9Ru/XB1R1L3uh69+iFd49e2Pb8d7at/E42c3nbyu9sW/kdf7frOaG6mnl1TKhV3XoinTU+vOXGyz+55cpPfn75J7d8+H9/ks5md+091j8xcWli4kIiEeck1K66ipDFZR4JVkL9wYON//pI664j583Rf+vjM+Gatpd3fy6rrrg0WYo6mQ6+tuRfR8dTo+Opq2atNv8YTaTGEqnRRGo0kXr96X8V10TtWdf7VtcDmFBTtO8+sPPOBxoOD6TGJlJjidR4IjWWSI1NpMcS6bFEaiyR/tUDS6++f2eKb+tsa2xmbxWU8cXW2e43YJ1W5syZI1rC5VtIJeLpxMWW8ZPrRnuejz10k61ca6SII8wJEuqM1tHRceH4cdFNJaHG4/GamhozcJiRNB6Pm8HUWmh9UkckFovV1uZCqqW2tjYWizk2QJ66drc/NjSaGh5LDY2lhsdSw6Op4bHCbfemxxzrN619Yd7hgdRXgwn77Q9PPXN4IDU0lh4aS/3hqWfItSorK9vb2z/++OPevN2739mxY7sZLp95cc8Tz2+f/0zbnN+/+puHX/rNwy+R4dIsbyZUSSVmMP1L9e+tqGrWxlSiMlZyoRd+XK3daIbUirW3ywtPSkKt2nr6d9vOzN9xdsHbZ5fu/fpP3QM7eodO6RN/fvbbmZHuzOgRY7Q7M3IkM3L4z89+28fter7K7+ccakNtVbeeSGYyx2+56extt+v3RM/edvvxW25KZbO7OnsGJpKDyWR8O/fDUl11FfnnANcZIkAJNbJ6b7imzRzBC5fHzD8OfN4XrmmTVRf4hLp+cYV5trpq1uph6yyWP5FtXvFv4provdMacZ8hit+PoiPENTOhJmlXV22756FlhwdS0UWb7np0483Rxv9z+3Phm54aHksOjaWGR1P3PLTsu1XbknZbZodCodlbCv/8/rJPOcX8sWU2sSlF5AnCPJWQ/5Sv60NIJS7uJy+2jp9cN9Kzsn/LXfrrP6TLtUYKB1VXXYXvj3ok1BnNTKgHt2+33xQTqq7rjY2N8+bNa2xsbGxsbGhomDdvXkNDg/lPc7lKJbW1teaVfXMuNhZrqK2tJTchmouVp64db/5BH029+U5PfPvRV7ceJidT9ZHUjrY/qLRN1/U34ysOD6Qu6BP2W9WCleSNXKuysnLr1q3d3d0nT548efLkqVMnOjr27N79jhkuB4aSolvlstwqZkKVV2LG079U/15SicpY6flpyH9+ZOePn+m86+Wup9/6vOWDc+ub54aqr1/fPHd989xq7cbQb74XeuHH8uGyAqjosn5p51Afif9i8dYHXnhv8RtdHT0X9x3ve33xt15f/C3jwoaNi7+18alv+btdb3xOqLW1Vd16IpHJfH30yPFnn/7w5zf+5dmnvz56ZCKT2bX3mJ5MXkkmmxwTqutwFZSE2tTxWejWNScuDhuGEa5pW7bl6HX3Nz7wykHDMK67X3oCCnxCfXlRhT6cumrWan04pQ+nHoi9c9Ws1eY/L4+kdr34U3FNtr3jOi4GPaF+N9o++5HY4YHU4HBycDg5MJwcJG4DQ8nZj8Sujm7mRUb3mdE7Lwk1SYdU9Xhq8hxS25bf07b8ntY/3hNv+LUVT0ePPc+Lp8zJoxSQUGe0jo6O493dB9u322/Hu7sVE6qu67W1teZHzklVVVVkypSIxWI1NTVmPLXeMFBTU2POocrfMCBPXW+98YQZ1wZ5QfDAnnWKHdzxdvz0SObKWNq69V1JmrcHFyx5rf3ga5sPvLb5wIMLlpBrVVZWbtu27ejRo2fOnDlz5kxn597Ozr0dHXusOdRnXtxTu3JHzbOb59bG76tpMmdS+65MVC7rNlcxE6qkEmYOte/KhDmHylSiMla6rt/58kcPaWdu1y7M77z04rEru8+MfjY4Eaq+vmLt7dXajWZUVRmu4udQ51UvsN/kG333pf/sGTaY2xej2cupzJVUat3v/8Y4Wbvu93/z1Z55kkqu4pFv1xvfE+q8ptY9r7a991r73viW/fEt+9t3fPTW7sPb3zvyTuexd/d/2nHweGN7N68l3IRqBovWSCiUf4IoXMsjZuKIYtQdZLIp3JvfTGskVFHXmrsEHWktFLHaQVyfZuMN97iZ23Tge1WNhmFEVu+NrN5rGMYPHnSfUNmtUlPKhX/wG0eOD9ET/rhxh4XfwTVP/K9LQ8lLQ8mrZq02/xgYSl66khwYmhgYSna+fo+4b/Z0SC7hNoBZSOxHTq9tBwlbhuh7RV0X1RzusLRGQhV1dezBYDIT6gTt6nvfnPOHF8w51OiiTZHH4r/83br/iKz8379sCN/01MXLE3N+/99Xz25l1prYfG/o+ud62KXWfZZ7N5MrPJe7x1q157nreSW5q3MKCJtAYE4Tc+bMcVzF4iGkti2/54ODHxzaf6jzvX3v7tj9yhO/FM+eFvaj4DWq7ehSOYQ4R2DhkGC2hIQ67eUTarv95iqh6rpeVVVVU1PTkFdTU2N9yZGcFU9V3jBgX12eujZtfKpPn2DmUN94+8hnJ/vGJjKX+lQ/R7G3c9chbel7677/3rrvH3lv7ch4emQ8PTCcHBhOxtZuPH1x/PTFxKmLidjajeRalZWVb7/99rFjx86dO3fu3Lm7l7TfvaQ92rDVDJdfD06IbpXLus1VzIQqqcQMpl8PTphRVVSJyljp5jRkTes/P7Lzx0/vvWtt19PbPm/94Fy1dmPo5/9Usfb20M//aY/m/P1fungOlVkur8RVPNV1fWfjf/UMGxcnqNulZHYolRpJJxLJi8apxelk7/mOank9ZYinuu8JtaZmXreeGEmlRtKp4XTq8oVPR9KpkXR6OJ3a1dkznE7F4t2ClnCv8ptPJlSeoEOXeRddrLDcSjZsACwEF3Ox+XxUqMxKhsJ5N3lCDd265osLQ+YfB3v7T1wcVk6oXXWRfEutjpD3Wo2zF6Ofp4nBEo0bvVzawZWPf//i5YmLlyeumrX64uUJaw61T5/YvOCbmxd8U9w3SUIV7he6VdZ+5PaaOUiEZXIlCn/KhoVYj2qLmVATtKt/s3HuosbDA6nzlxLnLiXOXUqcv5Q4b/0xkJj7ZOM1v9nIrJUwEyq71LyDuGfzvaHQvZvzf+X+7HnuerNIz3PX5xaprG79Yd3PWd/OnlAdVqC5CqlmPP3g4Af739/fsWvPji3bt77Rvqr6ZnE8tXZfyPbqy350qRxC3CNQeEggoU57HR0dxw8e7Ii322/HDx50lVAjkQiTUCORiMqKZjy1ru+7fcOAPHW1/unpr2z5b2g0XV1dfe+9986fP//UybPV1dV33XVXdbUsuLzfMv/Aa/8+PHB6eOD0gdf+/ZOO/x6dyIxOZPTR1HONG09eGD95YfzEhcRza2QJ9daFb352Ja0dOFxMQvVWicpY6bq+R2vYd3KEuf3tv9xlhtT1zXPdJlTPBUzq8VTX9bde+FnPsNE3YfQljf4Joz9p9E8Yl5LGcHpiPDOazFw2Ti3JJk982CKZdcopdTzVfU+o82pquvXEeDozns5cvvDpofprL1/4dDydHk9ndu09lshkGpoOClpCfp7G/ryi67r9UpsoS5JZh51EY+dFuuxVW3+bq/EjHPe4eTz+kZVQDcNo3PWZ+cd19zce7O0XdJzTNdssDz2nLCrGjA/ZD+64Sd8GwHRw+WM/MN/wftWs1bk3vw9MfDWY+HogsXnBN7OZy+KQyk2o+T1g3y+cVlFX+W2Dw3klISvDjcfCO9jrx/yEes+G6iVrDw+kTvWNn76YON03frovcfpiwpwzON2XmL/k5Wvu2cAGN1FCZZdbIZJJlubf5mwosYJs9fz/afycnCe6yu+USymKIdW8uN+2/J4DnQfee/e9Xdt2vNW6pe1Prc8/dJMsnjL7nXihYXvUKxxC/CNQeEggoU57HR0d3R0dHfG4/dat/Fl+Xddra2sjkUgtzVziuG5NTU1DQ611Td/tGwbkqWvjhvpzl9g51D2Hvrz77rvr6+sfeeSRUyfPzp8/v66u7u677xZV8umHW7SV//DF4TfNU8Rn3e9oK//h/KnD48nM8Hj66VUbDw+kvh5Mfj2YfHpVM7kiN1x2HuxS+SpTeUJ1W4nKWOn5hNpvJbyk8bf/cpf5h3krc0LVdV0xnuq63rbylp5hYzBpDCSNwfxtIGmMpJMTmaF0tt84VZ9Kf7V7/a9VaitpPNV9T6hV82rMT0olkolD9dcaX754qP7aZCaTzGZ2dfZMZDMNTaIHM/etZI4JtTDV6pBQOVHMMaEWarPnVO5x07r/xHX3N54fHGnc9dl19zcu3fzJ96oav1fV+Pbhc0s3fyLoON3PrroKa2NEt8w2FcaIW8xFQrVFdBv2M3ALfni2P2Herpq1+mx/wpw6NW/ZzOWRr/4sCKm2BClsGH0vtch6JWIfHE5sl5WRJVR7s/gJdZx2za/XLqhfv6B+/WP16xbUr3+sfv1jDesX1K9fUL9uQe6P9df8+uVxVvus0PXPHnNcfOzZ681/k3dYC61/hkLmvbLVZ7WLN8sl/6SUWh05KiH13Ks/yI780TAONTf8erf2jtb2Vvvrb7a80rxi7n/JV6SPFvELMJVDCAkVaL7MoZLxdN68eZFIZN68eW5DKvmxfVdvGJCnrlfXPXu6L8HcxhKZ6urqO+64o76+/u67737yySfvuOMOyRzqvvYnmp/8u0Pa0n3tT+xrf+KQtrT5yb/b1/7ERCozNpF+/I/Njy9rXriseeEfmx9fxiZU80NOJ06cOHHihBku3z/wsXl778DH0YatH3304f79+/fv39/RsaejY8+pU2bZE/ZPShVTicpY6br+9ubl+06ODKaMwaQxmDLMP7Ye1820dzllvL15uWR1C/fiPvdyv4+al1f2DBtXUoaeKvz3SsoYTSdTWT2bPmWcfnYidanl+V/6u11vfP62qap5td16Ip3NHqq/1th7k3k7VH9tOpvd1dmTymZrG4tIqPbLsmReo96paL/KT17Ds1/65/3dVVdHvU2NPxCMRW98NG/DoXePfW1+Xsr0yrufNe76TNBxnbpwSDSE7VVFJGINEb8Y84lm8VV+Yrn13og66ftQn5n/o9MXE9Zt84JvpvS3mNuVz5e8+fD/5PaO/iw/OdTc/cK0ivNKg+i1MF7wy0iu8tv3gSChjtFumN92za/WXPOrNVf/ao31x9V3rrnmV2uuuTP3zxvmt43ZHF16fSh0/dKj+X9vmnX90qNjY5tmkUs3zcr/o/DX2NjRpddfv/To2NjRpUs3FSqbtWlMuvqsTbk/cn+NjY1tmmX9yUF+t5RoiTp5SLXiqWFkDcNY98QvNzdval0fb37pNYeESn18n7oGwh5dKocQ/whEQp25zPehdrS322+K70ONx+NWPDX/MN88Si50/LYpktvpWHnqemXt8pMXE8yn+AeGUqdOnr311ltnz55dXV09e/bsX/ziF6dOnhVV8taK76RPr8gMd33WWT/ylZYZ/jD91fq3VnwnlclMpDLV9c3W90NX17EJddu2bZ988snp06dPnz5thkvyQvzdS9qPHOnev39/Z+feEye+OE0gE6q8klsXvmlVcurUCW4lKmOl63pLy5p9J0eGUsZQ2riSNq6Yf6SMnafHhtLGUNpofWONZHXLpCTU9c/e1jNsjKTZWzI7nsleMs7GspmzY5nM+mdv83e75eGQUCNVtd16Ips1DtVfa3TPN2+H6q/NZo1de3uyWcMwDEFIVUmouuyTUpGIbbn8EzbOc6j2z17ZB8Kued+Xj8c/Mj8sFVm99/H4R6KShU3wLmJXRCIVdB+di5Ef8KiL0PnLPm5kNQ4fBXvq4R+Z7yIyb+tnfyN1cR1zm/jyD68/8D9sXaS/D5XZydzPe7GtIt6Hyuk1ZwbdPjK5peqflHKTUEk3zG+75vZVV9++6uo7VnFTKWvTrEITClmRu5SXUMmizqvPItKsbSUe69Wq40JFopBKx1PzdmhV9S3Na19XmUAlDzLJO0LUDiHuEYiEOnMV/32ouq6bk6ZMiDRjpblcvT0epmPlqeulF1d88fX4F1+Pf0n899JQqrq6+uc///ncuXNvvvnmuXPn3nLLLZI51M3P/X1m6EBGf3/j0u9vf/Gnmcu70181bX7u7zOZbDqdvb82bn1j//21bELdvn17T0/P+fPnz58/f+vCN+23Y8eOfvHF5+dtyISqUsmJE19IKlEZK13XX3m1ad/JkdGMMZo2cv/N//HxubHRtPHKBtfnhJKmUlJj/Z09w8Z4xhhPG+NpI5ExEhljIpvOGIPG+cas8VUyO5HIGI31d5auDaXjkFBvr2owf/X0xLr/OFR/rXk7se4/DMPY1XnMmlMUz6ROGdP+aYnp4KJ5//b4Qz9eOO/HLyz+6cYVN2ov/df62d9YP/sb62f/1frZf5U68czE0ej63/7VZLW2bMyEOmpzw/y2a26PXXPbitx/b1txzW2xq2+LXXNb7JrbYjfMb7OvMmNxQ+rFT+cz8TQ78sfYQze5ub4/Oab9qQB8+U0pXde58dGMleqNUZmOta8lT12Njc8zty1b2k6e/PLmm29+6KGHqqurzU9KzZ0792c/+5mokj/XfTszdOj8kRdqfvXXNb/66/NHXkh/te7Pdd/OZLOZbHbWwvjhgVQimUkks/cupGaLmXDJREx7oCSR3zZVfCUqY6Xreuyl+L6TI4msMZ41Elkjkcn/N//H8y+94bAX88o8garr+vOLf/3psJHMGMmMkcwaqWw2k75sXNxgXFyfNfrS2WQqYySzxvOLld6HGjTOCVXl1hBzcTkjmKb905J6B9dGvjFxNLo28o2SticgzIQ6AsUxT75kTu079Zp5cd+Kp8nPnwh+PNVnwKkAgsbDdKy330mqrq6+6aabzM/yP/zwwzfffPPDDz8sKty65Nv6X5anz710fPfvju/+XfrcS6OfN7Qu+Xbbzk8a3zjw5Kodd9fErRu5oj1cMnOfknB59uzZs2fPchOqh0oUx6rhhT873twOddmsXvrb1Ut/u3bl/Qf2tYycWmlcfNnof+Pi+Q/fa3l49dLf1j8ZsW6T3VIvHBLqzDHtO+4qoc6QeKojofpK/rbUqWLanwoggNxOxxb5W/MqzE9KMbd97U84rlhVVdXW1vbpp59+5Z4ZMauqqnyppGxjBSWChJoz7Ts+7TvojZlQh8En9snUKQePFAi+IKeueDz+wAMPvP/++2fd++STTx599NF4PO5LJWZ7gjxWIIeEmjPtOz7tO+iNmVCHwFfWm66mYlTFIwWgSM3Nzffdd1+le/fdd19zc7OPlcCUhoSaM+07Pu076A0SaklNxaiKRwoAQBBwEirATHMFSmyy9zAAAEw9bEItf0wGAAAAALAgoQIAAABAsCChAgAAAECwIKECAAAAQLAgoQIAAABAsAQjoXbVVYQq6rpKuYnWiE9baI2EIq16Wdo8/fkxmNNyR0zLTinpqqswjwn74pk5IH73XVRb4Qwp2AWeawYX/Dj+sSMmSWsk5MDatV11FdhFCpBQHVdjjq1SJVTqzNQaIQ9muiW5jUo6lCtK1laS0e2qq2Bb6dKkJdTcEHHW66qr4J5RdPE4kqsUNRx0ld4GRNRI+5EcBPbWli2hlupR4b/pk1Ctg5Connj0KG1UVL5wgIur4ZxXFWtgT79K98pO4+ZiX45/WyVTM6EWes7fxcqDrH5EddVVCPaoqB4qgzqMcf7ZTVC38x7iHq7yY1i3d0p66DoMdSH0TNbx5C2hej2F+cllGzyMMXMotEYq6rrkh50TcZsLB6x5fEUiFexZvJBMC49jfpfYJpbo+Oqqq6ioKO5A8DyYfhyB/GGR1cwZcTal544S/7juKaeR/CM5EGytLd+5BbMYlOITqoOuuorCE17huc/aB0qbJVYlc5jzKY57XqUrlkYV2+lXfq/oNM6OgC/H/3Q4kgt94B4S6oOsfkTlnsAEQ8evx81zqeTZTTzZ6hQDZMcwp1PyQ1c01PbH6aQdYkiokhW49ZckodoqpUtS/6IfLipNLE1CNY/ZYoZjyiVU2+O0DA8E95tgGyk6koNhEoZUtOmZreQJlbstksr+INe0/lbfkaKuSWsQnX6d7xWPpLDtngZ/6h/JgmeCfMe8DbJ0XKznL4WRI+OzDwmVPiNLJgy4XXOeQxE8lOWHFm+smEfbZDyLKCfUwlwREf+JcE7PI5tj0RrJLWqNhCrqWnPzyZHWwhq2cWyNhCrq6uh781sn5p1V2qCzr1SolwtOh5nwSCQvTHPm/qkX9VRH7G0mB1d6rYc+OKjjT3C9TphQ2ZGkxqLwD+cLJfltUwNF7HdqXdFytcGU733Buuy7HOwHlXpCpceFeuUgO45Ujgq6Suvv3B+uj3P76Vx6ThUPl+TR6lzA1Y7gPt/YDhXXpwi6qopIpMK+6+37mrvLPAxRAe8BZ9vdok6xxfx4/AofL7wj0qyHe/KhZ0LpR6K0O8JDkj1vkdcnyElHa9+Rp8H81uRndsGTtLwG0enX+V7ZlISvx794RsPrASPb0WxXqHHj7jXBiYvsNXe/5QfX0yDLUhX36UuoUA/xgFGZ7+fN0dpnEIpJqOT+tHeKO278/MMZK/a5fTJeBTkm1PyRK3ydx8Yf62HAvnnDLGXu4cIkPXPWJq5Hko+eCBHk2ZVFbaBeqLRGOF2QHWcuEqpw65yO8B9L9oND9tqHPndw6hMnVN5Icl5wcQdcND72/EvsFmIIeMu5g8kMvNPeF61LbcW+L2QJtYC7Fh1UbNHf5VEhS6i64nEue06VHcni4ZI8WtUKuNsR9BmXc6h4PUWEeINHPeFQWZ4ZKs9DRPZGvMShU/ZV/Hj80hvlnSHzJXhHFrl2RUWFNQZ04Bd0J/8YcQpttoXsUyV96ia25jT7IDgDS2sQn34d77VtjjsCPhz/dCV+HDCyHU013X5Gsu81fjHRENhrdzfI/GIk/pO3CLeMw4FWWK+rTvZeV92/hMrpFH/ceE3nPsLoTYvjfilJEyr5aohCdJx4TREqRFnJEcX7W5j2JFMkTm1gDivRkSjqo3pC5Y8AtyOyV/DiaRPJK0j+6xpxQrV6zMtS9iOfKiYcHro9ZGlO4KKX8wZT8BJbuPeF63LvIEZMnFClD0RidDk15O9VPyrUE6rKca7USO5y7nBx/3Yq4HZHCJ5dqX8WeYpg208GM/FAeR8isor8zrf3T6FT9n4U+/gVPV6Y4BKJyM/9rZGKui7zydV+JN+y09wAAB78SURBVEu7I3opwH/UMQPInGw4x5s0c4gTqqQG4enX8V5ZeKJf+hR//BOV+HLASHY01Q37WU5n95qwGLFt2z5jXz+5HGT6iLJaQL+SoqqiygjqYbYgj6iFRpMp1TYYNvQpzSGh8pZSLw0kh65TH+mjlB82Sk15DpXqAf2s6fw0X1xCJXev6Jnb3gaHhMrtl2R9crlKqHKTUDmvTmwJlX/UCl968vcWfyQLr/WIuzjF6C0wuJnAj4TquPdlCdWeqIpPqMxJzZ5IXB4VrhKq43Gu1EjuYu5w+ZVQpTtC5UVOkacIorTw3KSUUBWHiGGebcS7WzGh+vL4VUuo3OuTRPOIyNJqP705JFRm2+IQoHOyjj1K0lvwklDlNQhPv473Sk4m7AgUdfwzlfhzwIh3NL8TzB3CvSYYDXZQqQUuB1l6RBFRnHn64nZDdmSqJtTcZkVjJaxGPaEKOiU/dPOtVOsjP2yUmof3oeq2kES+1JHPXgj+lj/8mIcv5+mH2wZyIfkQJF58S9HrWAeSLVQJt+4qoXJyGf9ByFTsnFCJ3vJH0mxgJMKLblQxcgPs+YM4I1KDTkRjznL5YLbW1XU57316Xd4Ju+iEyhwwRB3sQVIYe+Wjgqi80EF+zHI8zlvryNORqJGFI9lxuDwlVLc7gvqX4FAp9hRhFSeOc3bT9pH0OkTWPu2qq2POmdzdLT8weJnS9ePXXpvwDEk2lXyUFe62vsPD/NsWbgTdITdGrMM+Cm1nrMICqjh12pHUx1RdOCS49VIDZTtvWz2T3yvaHGcEqEHyePwz//LlgHHY0YVHuu2MZNtrgmIE9lnNtguVB1nx2Z23YfsWbXcV2k6fGkR1q0Q6/96HSmyY84JHcOhyHn3co1QUXkrM4/eh5hJ7oZvMSxFfEyqxAfKbFpzakH8hZxaqc3wZx1OoIUTsZ+aUwd06/zxCtZneDqcussLCYnpcBYG38BRErcEfSVsQFRUjRoVell/SVZe7Psg0VbRcPphEupXsfepY4+wwDwmVwIZIthLbGoU73B4VZAeZBC4/zrnHBtNI7sA4D5e3hOpyR1D/FBwqXk4RnHMq73mFzfK2NrsfIubJ2d4VtqlqCbWYxy+nNtEZ0l4i0ko+BATJ1TFF8R8QFKrjxM6io5r9QOYMM4N3XrXlXaoGW5dte1Fy2PBP49yHLz1K3o5/+5FT9AHjsKPtfbfPExDri3tujX7hCdZ+SKgPsmh1AWFCFdVjLXeOE8UkVO7x43gM8zolOXQFfeTvq8mZQg3IN/YDc6opbp1JOpZ08eusSXr9JSd++ewokP1hTYlGWsrTWu4+D/pA+du+oPd2hvJlt+QqmYq72MszYMAVP4caHJO2e5BQg8LtWUWSr2xTp2UzZRJqboi8P+gm71WAC1OikZbSt1Z4GAZ6oNxdtixvbUHFzg4Fd+8W+HIQtkZCkbqpuYsD9yQBeUVM5hQLCRV8NGUSKsw0+cvVk90OV/x9rTl5r1yhTLCLYXpBQgUAAACAYEFCBQAAAIBgESbUJgAAAACA8nJIqAYAAAAAQBESicTZs2e//vrrgYGBywRd183/Wq5cuTI0NNTX14eECgAAAAAlhIQKAAAAAMGChAoAAAAAwYKECgAAAADBUpKEqkXp3+WIaqVouhYNhWO9AaknFrY6G42GY8W3qmy0aCjkz0ACAAAA+KOEc6i9sbB68ImFSxNjy4LsqRYNhYiE6rZfkzIObnYUAAAAQMmJEurAwEB/f//AwIBvCbU3FjZnGNmZ1d7C/CMz5WreEY715ovk7rHWUKqfqCoUCoXC4XA+QXLrMRWmgcMxxwDHz+LifpGTzIUVJeXJu5wmaG3V8DtIioXDMc1aDWkVAAAAJhk3oV66dKm/v//xxx8nQ6oPc6i9sTCZMsl7hXOHZpgzY5kWJQup1y+Z4+TWo0WZ/Owc2ogEHKOX8/qlaRqxIlmCW55sYG8s7BhS3YqFiWDay7QIAAAAoNzsCdWMp/Pnz1+0aNHKlSutkOpPQiXnERUTqigeuqmffGcsuyFbPVoxbyRlEiS/X/Q8p0NC5UyKyhKkpznUEBP9EVEBAABgEjEJ1Yynjz766NKlSzds2NDS0tLc3GyG1CmdUKkKneZQi0qohqFFibzH6xf10SwmDvLLl/ijV8wAIKECAADA5GISan9//4oVK5qamrZu3bpr166Ojo7Ozs49e/b09/eXOqHm/0VeYrcVY2pTrJ8qSAVIfj30p/uZBtnRxel8x+lXb8x6Iyz1vgRRef++tUDEfCMD0SQEVAAAAJhM3DlUO3dzqNxvm7KuPke1QolC8NLsn3ASfWkVu9y8R1I/fd1bWH+ImvtUu6bOqYedkLVXQ1yID0ej4RD/Q1SCT3qptMgN89umzGZw2g8AAABQdvjGfgAAAAAIFiRUAAAAAAgWJFQAAAAACBYkVAAAAAAIFiRUAAAAAAgWJFQAAAAACBYkVAAAAAAIFiRUAAAAAAgWJFQAAAAACBb/E2ov/fNH5q8UlaLpfv0WqC/1FDodjUZL09+SKvyUVThG/27rZDapdD9v5aq/1iFt/5Vd/AwXAABAKZRkDpX6pXvyZ+jFghGKPCL7q0WpRO62X5MyDlq08EOqZuoK7M7wZXy89Zc6qhWWAwAAgGclTagaNZuYn3GKatYUVjjWS/1KPfOr8+Yd4VgvuaohmLvKRY2o0+/ah8NWYpbMgZFzbI4JhJ9RxP0iag9RUV5UnrzLKe5z5rDlk3zSKUSisqhm1R4OR80luY5EtVzJcCwW5W6Trce+3HG/+DQ+sv5y9wuxHhIqAABAeZQqofLjQm8sTKRSMicIU4MZGsx6tChZyJ4MyFrJeyVznNx6bHNszgmESFoxejmvX5qmESs6jgMzJe3zuya0qKh7+b2VK5bbrjXK+WGyIh81Hdlb6Bm/Hvf7xfBlfMT9lewXUXskywEAAMCzMs6hmnqtiVFqsSShip7+uQmVnKck7iUmx2xXdG318JqtjElI/H7R04EOCZUzKSq7KO16DlU0wra5xlxB620bWtSaV7USKvMSggqwnA262i/mJoodH1lCFe8XUXskywEAAMCz0r8PlZHPJMzTf4kTKt0Ah7m6ohJqIbgZhsHvF/URICa/8cuX9KNXojcKe0mo7GV5p4RKLfU6h+pyfIRvjJbtF1F7JMsBAADAs3IkVOu5nrgKb17UJcvk/0VeYjf8SahUQSpA8uuhP0XONMiOLk5HG06/yITEebcDZxxK+ql2W/2FDdMDkw+C0jlU7vwxvx73+8XwaXz4/ZXuF1F7JMsBAADAs7J821Q+ABT+kZ9Jpd6eyF5cJS8Bk3ewyx3rp1skrD9EzX0qXjO218NOyNqrIYYoHI3SnyXnlRd3wTf8/tqvepOjrEVDxOfYopoRC+e6ww6E4Oq5h/3i1/hw+yvYL6L2SNsJAAAARcA39oNvMJkIAAAAvkBCBX+Ivs0AAAAAwC0kVAAAAAAIFiRUAAAAAAgWJFQAAAAACBYkVAAAAAAIFiRUAAAAAAgWJFQAAAAACBYkVAAAAAAIlpIkVNGPQfnLr98C9aWewreBRqPufiYeAAAAAGglnEN19Xvl1I/ZTzVkT7Uo/7fpFU3pcQAAAADwRfkSau7X26O231Wnf7Td/rvt1i+/W/dYayjVT1QVCoVC4XA4nyC59ZgK08DhmGPS5mdxcb/ISWbRj9dT5cm7nCZobdXwO1hMfwEAAABKqqxzqL2xMJkyyXuFc4dmdDJjmRYlC6nXL5nj5NajRZn87JzYRL/5ye+XpmnEimQJbnmygb2xsO8/K+qhvwAAAAClU+6ESs4jKiZUUVxyUz/5zlh2Q7Z6tGLeSMokSH6/6HlOh4TKmRSVvRPA/RxqUf0FAAAA8N0MSahUhU5zqEUmNi1KJEhev6iPZvXSJfjlS5sgkVABAAAgWIKTUPP/Ii8524oxtSnWTxWkAiS/HvrT/UyD7OjidOTk9Ks3Zr0Rlnpfgqi8f99aoNYBx/4CAAAAlFb5vm3Kuvoc1QolCsFIs3/CSfSlVexy8x5J/fR1b2H9IWruU+2aOqcedkLWXg1xIT4cjYZD/A9RCT7ppdIi99z0FwAAAKC08I39AAAAABAsSKgAAAAAECxIqAAAAAAQLEioAAAAABAsSKgAAAAAECxIqAAAAAAQLEioAAAAABAsSKgAAAAAECxIqAAAAAAQLP4n1F7654/MX1kqRdP9+i1QX+opdDoanYo/c1/4KatwjP7d1slsUul+69VVf61D2v4ru9zlAAAAUKSSzKFSv3RP/gy9WDBCkUdkf7Uolcjd9mtSxkGLFn7q1Exdgd0ZvoyPt/5SR7XCcgAAAPCspAlVo2YT8zNOUc2awgrHeqlfqWd+F968IxzrJVc1BHNXuagRdfpd+3DYSsySOTByjs0xgfAzirhfRO0hKsqLypN3OcV9zhy2fJJPOoVIVBbVrNrD4ai5JNeRqJYrGY7FotxtsvXYlzvuF5/GR9Zf7n4h1kNCBQAAKI9SJVR+XOiNhYlUSuYEYWowQ4NZjxYlC9mTAVkrea9kjpNbj22OzTmBEEkrRi/n9UvTNGJFx3FgpqR9fteEFhV1L7+3csVy27VGOT9MVuSjpiN7Cz3j1+N+vxi+jI+4v5L9ImqPZDkAAAB4VsY5VFOvNTFKLZYkVNHTPzehkvOUxL3E5Jjtiq6tHl6zlTEJid8vejrQIaFyJkVlF6Vdz6GKRtg215graL1tQ4ta86pWQmVeQlABlrNBV/vF3ESx4yNLqOL9ImqPZDkAAAB4Vvr3oTLymYR5+i9xQqUb4DBXV1RCLQQ3wzD4/aI+AsTkN375kn70SvRGYS8Jlb0s75RQqaVe51Bdjo/wjdGy/SJqj2Q5AAAAeFaOhGo91xNX4c2LumSZ/L/IS+yGPwmVKkgFSH499KfImQbZ0cXpaMPpF5mQOO924IxDST/Vbqu/sGF6YPJBUDqHyp0/5tfjfr8YPo0Pv7/S/SJqj2Q5AAAAeFaWb5vKB4DCP/IzqdTbE9mLq+QlYPIOdrlj/XSLhPWHqLlPxWvG9nrYCVl7NcQQhaNR+rPkvPLiLviG31/7VW9ylLVoiPgcW1QzYuFcd9iBEFw997Bf/Bofbn8F+0XUHmk7AQAAoAj4xn7wDSYTAQAAwBdIqOAP0bcZAAAAALiFhAoAAAAAwYKECgAAAADBgoQKAAAAAMGChAoAAAAAwYKECgAAAADBgoQKAAAAAMGChAoAAAAAwVKShCr6MSh/+fVboL7UU/g20GjU3c/EAwAAAACthHOorn6vnPox+6mG7KkW5f82vaIpPQ4AAAAAvihfQs39envU9rvq9I+223+33frld+seaw2l+omqQqFQKBwO5xMktx5TYRo4HHNM2vwsLu4XOcks+vF6qjx5l9MEra0afgcFvfVnWhoAAACgGGWdQ+2NhcmUSd4rnDs0w5MZy7QoWUi9fskcJ7ceLcrkZ+fYJvrNT36/NE0jViRLcMuTDeyNhf3/WVFxewAAAADKr9wJlZxHVEyoonjopn7ynbHshmz1aMW8kZRJkPx+0fOcDgmVMykqy5Be5lDF7QEAAAAovxmSUKkKneZQi0qohqFFiYzH6xf10axeugS/fGk/eiVrDwAAAED5BSeh5v9FXmK3FWNqU6yfKkgFSH499Kf7mQbZ0cXpiMfpV2/MeiMs9b4EUXn/vrWAT9oeAAAAgPIr37dNWVeSo1qhRCF4afZPOIm+tIpdbt4jqZ++7i2sP0TNfapf9WbqYSdk7dUQF9XD0Wg4xP8QleCTXiotcknWHgAAAICywzf2AwAAAECwIKECAAAAQLAgoQIAAABAsCChAgAAAECwIKECAAAAQLAgoQIAAABAsCChAgAAAECwIKECAAAAQLAgoQIAAABAsPifUHvpnz8yf2WpFE3367dAfamn0OloNFqa/pZU4aeswjH6d1sns0ml+61XV/21Dmn7r+xylwMAAECRSjKHSv3SPfmz72LBCEUekf3VolQid9uvSRkHLVr4nVMzdQV2Z/gyPt76Sx3VCssBAADAs5ImVI2aTczPOEU1aworHOulfhWe+dV5845wrJdc1RDMXeWiRtTpd+3DYSsxS+bAyDk2xwTCzyjifhG1h6goLypP3uUU9zlz2PJJPukUIlFZVLNqD4ej5pJcR6JarmQ4Fotyt8nWY1/uuF98Gh9Zf7n7hVgPCRUAAKA8SpVQ+XGhNxYmUimZE4SpwQwNZj1alCxkTwZkreS9kjlObj22OTbnBEIkrRi9nNcvTdOIFR3HgZmS9vldE1pU1L383soVy23XGuX8MFmRj5qO7C30jF+P+/1i+DI+4v5K9ouoPZLlAAAA4FkZ51BNvdbEKLVYklBFT//chErOUxL3EpNjtiu6tnp4zVbGJCR+v+jpQIeEypkUlV2Udj2HKhph21xjrqD1tg0tas2rWgmVeQlBBVjOBl3tF3MTxY6PLKGK94uoPZLlAAAA4Fnp34fKyGcS5um/xAmVboDDXF1RCbUQ3AzD4PeL+ggQk9/45Uv60SvRG4W9JFT2srxTQqWWep1DdTk+wjdGy/aLqD2S5QAAAOBZORKq9VxPXIU3L+qSZfL/Ii+xG/4kVKogFSD59dCfImcaZEcXp6MNp19kQuK824EzDiX9VLut/sKG6YHJB0HpHCp3/phfj/v9Yvg0Pvz+SveLqD2S5QAAAOBZWb5tKh8ACv/Iz6RSb09kL66Sl4DJO9jljvXTLRLWH6LmPhWvGdvrYSdk7dUQQxSORunPkvPKi7vgG35/7Ve9yVHWoiHic2xRzYiFc91hB0Jw9dzDfvFrfLj9FewXUXuk7QQAAIAi4Bv7wTeYTAQAAABfIKGCP0TfZgAAAADgFhIqAAAAAAQLEioAAAAABAsSKgAAAAAECxIqAAAAAAQLEioAAAAABAsSKgAAAAAECxIqAAAAAAQLEioAAAAABAsSKgAAAAAECxIqAAAAAAQLEioAAAAABEspEqoWDTGimmFgOZbP7OUAAACgCnOoAAAAABAsSKgAAAAAECxIqAAAAAAQLEioAAAAABAsSKgAAAAAECxIqAAAAAAQLEioAAAAABAspU2ooVDIQ5tcreVtEyq1if52XJ1bmP2KTELRrXbHvkVJG1wVdlXG1YrlHyUAAACYRCVPqG6TmSTkOVbIrdlVA0SpVDEhWcXUgx23pGLvXI2GpDuS3ql0xFUz5EQ7xXOFAAAAMBWVMKF6yBCSFFUeZJ7zkIrkUc/3Ol2tKPlnkQnVQ8NE3VfcHOIpAADA9FaqhBrKT4UqZjLucnlhD2lPwl6JJMNJGqCeveTLyQ157pHiP90OsmRnud0pIcFxotgGz4MDAAAAQVaShBrihTyLPSq5TWne0p4KeTZSX517l9uMZaU3QzpKknin3jb1u9wOvuPOdbU59U4BAADA1DU570PlNqXIkvbykmKSVZg/7HdJ+BWYREGTOyaKXZC0zdVdRe4USQtFS9R3n1tatFBPVJOV7I2FzWLhWG8xWwQAAAAVk/BZfr9inCtMzhOVsUKPSpa13yXqrwqysKjl3CWifzrW4+0uX3afNchMnfLKFTetmlx7Y+FwTKVCeg0kVAAAgJIL0ByqOsecx12F+7e9WkMQcUTp07GM41pFFg5IQnW7U7jNU9k1ii3h9yePnD0NhUIhK6oSd9jDKDeh5mdXQ6FwuBB5ewuLQy5zMAAAAJT8G/vVQ5vb0GlfXV5A3iQmACm2xFsKdOyUq9EQtcHtcsUGqO8aeRnm3hAvoTIbIssoHhgy3DlUTbOu9sfC7KV/e0Ill2jRQhglC/bGwgipAAAArgRlDlUUOIqMQdxKFHOkSgPUyzNpzMfREA0vt9eiBvsQ+GxNkheQNEZSoWI4VsJNqOTcp+3Nqbw5VN57WelKeDUBAACATAm/bcqeQiTZQnE5N++KIpqkEtFwMDHIbc3kEslGHQOWq1FyNXSSMoqVc5e43Skqo2Rvdog4ouQ70XGEDYObULVoiJr7VEio7Nq5vzBpCgAAUISSX+U31Oa9XGWyIgtIYhn3n45hiOkdd63SJVTFShyzpkoYVWyG+r52bIO13B5qVQrL2BMquaQ3FlaYQ6UWaFFrBSrqAgAAgEvluMov+qe9pOPcG3dFt/cqJiR5MXnz5JlVpVPeRkPUF3nzuKt4GFjFTauvyO214hElx16G51yfD0ej4fw97AerrBXoeqhAK7kLAAAA5Er1jf2O6U0SO1SWO25FcV1uM7jVeg6I9kTFpdJyxQZIRkZxxFQ2JKnf1UCpr+itZgAAAJhyynGVHwAAAABAHRIqAAAAAAQLEioAAAAABEu5f/VU/R2W6u+5VO6su9pEfzuuLn+DpvwdqGXgaqi97RfPnSryDbgAAAAwPZT1N6WKT0KSnCf51JF6NPQloap3R1RSsXeuRkPSHUnvVDriqhlyop3iuUIAAACYikqYUNXDikrqKs9wkHnOQzMkBTxHN899D0ljaEgtf8t3lueGibqvuDnEUwAAgOmttAnV8W+DDoXc5Xae056EvRJ5m1WodEfe5mI6VWRCddU7eXnHRopWcTvIAAAAMD0EIqFy04YkfIjuKj6vyLOR+urcu9xmLCu9GdKoKol36m1Tv8vt4MvHzbGR8gJIqAAAANNSIK7yG7yZVFHSUq9ZUkyyimSjjqPpV2ASBU3u6Cl2oQwJVXF3uxpkV7sPAAAApofJn0MV3SvJMR7IG2Att0KPSpa138Wt2TFjMTXYNyTpi+SfjvV4u8vH3eF2XytuWjG5xsL4JVIAAICAmvyE6hiwuCFJnvPsJA1gqjUEEUeUPh3LOK5VZOGAJFS3O4XbPJVdo9gSfn9MvbEw3UIrq5p3hGO9+SJRLV/cLKNFcwU4VYVjso0CAACAssm/ys8sV4849krkBbh/MwtDRLxTaQY3ZnlrAFNYZejkbXC7XLEB6vtFXoa5N8RLqMyGyDIqR4WccA41H0LNv81CvWRpLWol1FiYDqsIqQAAAH4o029KecgTiqsoRiXFmu13qQdfeXkmjbkKnfLlouDI7bWowcUHPnuT5AUkjZFUqBiOVUgSaiF15vETqm0ulpiNBQAAAO+mWEIVzuZJM5/bhOq5ZnKJZKOOo+E2oaoUdmy/YuXcJW53isoo2ZsdInKtfCc6jrDhS0I1tCgmTQEAAEqgJAnVW2TxFuk8pD1Jzdx/OoYhpvHctUqXUBUrccyaKmFUsRnyAurjTy63h1qVwhKFC/RalJr7FCRUct7UKqBFQ/bCAAAAUKTJn0MV5QlfEqrbmkV3cfO0JAnJM6tKwlOJ9Y6VyOuXr+JhYBU3rb6i6MUMU0BSoYz5ftNQiIinhUXMHcQF/XAsFg0RIZW+0o+r/AAAAD6Y/IQqIU9mjqHNMaKJ0g+3Ws8B0Z6oHKOnaEOKDXAcNFdtdiysuGnH2hxX9FYzAAAATDllSqgAAAAAAIqQUAEAAAAgWJBQAQAAACBYkFABAAAAIFiQUAEAAAAgWJBQAQAAACBYkFABAAAAIFiQUAEAAAAgWJBQAQAAACBYkFABAAAAIFiQUAEAAAAgWJBQAQAAACBYkFABAAAAIFiQUAEAAAAgWJBQAQAAACBYkFABAAAAIFiQUAEAAAAgWJBQAQAAACBYmIR66dKlfp6BgQEkVAAAAAAoByah9vf3L1y4cMGCBQsWLKipqVm8ePGaNWtaWlr6+/uRUAEAAACgHLhzqMuXL1+1alVTU5OmaXv37sUcKgAAAACUj/19qGZIXbdu3fbt2z/44AMznuJ9qAAAAABQJmZCvXDhwuDgoPWhqIGBgf7+/p07d1rxFAkVAAAAAMrETKj9/f2XL1++QhgcHLx06dLg4KC1ZGhoaHh4GAkVAAAAAErLTKhmEh2SGh4eRkIFAAAAgJIzE6qu6/Y8aqVSEhIqAAAAAJSWmVDtYXRkZMT8LwMJFQAAAABKy0yo9iQqgoQKAAAAAKVlJtQ+NxwSasKlkZERt6sAAAAAwDSmeyVMqKdpZxScBgAAAIAZQCUZnjlzxv+Eep72lYLzAAAAADAzMDnwwoULfX195jfwDw0NkW8q9TOh9iu4RHP1JgMAAAAAmELkaXBgYMD84Sjzk/ulSqgDtME8M4maPwPAGAAAAACAmYGJhZcvX9bzP15a7oRqtmPFihV9fX1IqAAAAAAz1uDgYF9f38KFC82QOmkJ1Yynjz76aFNTExIqAAAAwExmJtQFCxYsX77cDKmTkFDNeDp//vylS5du3boVCRUAAABgJrMS6qpVq9atW9ff3z8wMFDuhNrX1/f4448vWrRow4YNu3btQkIFAAAAmMnMhFpTU9PU1LR9+/adO3f29/dPzhzqypUrW1paOjo6kFABAAAAZjIzoS5evFjTtA8++GBy5lCt96E2Nzd3dnYioQIAAADMZGZCXbNmzd69eyftfajkZ/n37NmDhAoAAAAwk5kJtaWlZZI/y0+GVHwfKgAAAMBMNhic70OVm5TRAQAAAIDyY3JgmRLqZQAAAAAANWQ8LWFCveKe50YAAAAAQMA5RkEynpYqofa5dxEAAAAApikP4dD/hAoAAAAAMCmQUAEAAAAgWKxE+v8BaoY5lRqionwAAAAASUVORK5CYII=" alt="" />

  从运行结果可以看出,一个复合享元对象的所有单纯享元对象元素的外蕴状态都是与复合享元对象的外蕴状态相等的。即外运状态都等于Composite Call。

  从运行结果可以看出,一个复合享元对象所含有的单纯享元对象的内蕴状态一般是不相等的。即内蕴状态分别为b、c、a。

  从运行结果可以看出,复合享元对象是不能共享的。即使用相同的对象compositeState通过工厂分别两次创建出的对象不是同一个对象。

  从运行结果可以看出,单纯享元对象是可以共享的。即使用相同的对象state通过工厂分别两次创建出的对象是同一个对象。

享元模式的优缺点

  享元模式的优点在于它大幅度地降低内存中对象的数量。但是,它做到这一点所付出的代价也是很高的:

  ●  享元模式使得系统更加复杂。为了使对象可以共享,需要将一些状态外部化,这使得程序的逻辑复杂化。

  ●  享元模式将享元对象的状态外部化,而读取外部状态使得运行时间稍微变长。

原文地址:《JAVA与模式》之享元模式