享元模式采用一个共享来避免大量拥有相同内容对象的开销。这种开销最常见、最直观的就是内存的损耗。它把产生的对象放到一个共享池中,等到下次又要产生对象时,先到这个共享池中对比一下,如果相同,就不产生使用共享池中的对象,如果不同就产生并储存到这个共享池中。
看如下代码:
Integer i1 = 13;
Integer i2 = 13;
System.out.println(i1==i2);//true
结果为true,说明i1与i2是同一个对象,它的内容都是13。
实际上它也采用了享元模式,对于这些基本数据类型的整数要装箱成Integer对象的时候,如果这数字在一个字节之内,也就是-128~127之间的这些数字,一旦把它包装成一个Integer对象的时候,就会把它缓存起来在一个池里面。下次又要把一个整数包装成一个Integer对象时,先去这个池里对比一下有没有,如果有就直接到这个池子拿,这样就节省了空间。
在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);
}
}
【总结】
Java的面向对象虽然很好的解决了抽象性,但在编程时会产生大量的对象,如果每个对象都占据着独立的内存空间,那么内存拥堵就是常见的事了,而享元模式就很好的解决这一问题,因为在一个程序中对象多,但很多都是相同的对象,有了享元模式的存在,相同对象中只产生一个对象,,很好节约了内存空间。