单例设计模式是java23种设计模式之一,它是解决一个类在内存中只存在一个对象。
如果有两个程序去访问同一个文件C,如程序A与程序B,其中程序A对文件进行修改,B程序进行读取,按说B会读取到A修改后的文件信息,是不是这样呢?实质上我们知道他们要想访问文件C就必须在各自的程序中建立文件对象,那这个时候在各自的程序中建立的对象就不是同一个对象了,这就要保证对象在内存中的唯一性了。
那么保证一个类唯一思路就有以下几点:
1, 为了保证其他对象建立过多对象,先禁止其他程序建立该类对象,只要将构造函数私有化。
2, 但有必须保证其他程序可以访问该类对象,就在本类中自定义一个对象。
3, 为了方便其他程序对自定义对象的访问,可以提供一些访问方式,也即提供一个方法可以获取到本类对象。
代码的实现如下:
class Single
{
privateSingle(){}
privatestatic Single s = new Single();//下面静态方法在访问类中成员,故成员也应被静态修饰
/*只需要get方法,不需要set方法,因为只能获取对象*/
publicstatic Single getInstance()//不能再创建,只能类名调用。故静态修饰
{
returns ;
}
}
这样,在主函数中再new对象,就会保证在内存中只会有一个对象,而其他只是引用在指向它。在代码中描述事物时,事物该怎么描述就怎么描述,只要将上面的代码加入就可以保证对象的单一,这就是单例设计模式。
单例设计模式有两种方式,一个是饿汉式,一个是懒汉式。
饿汉式代码是:
class Single
{
privatestatic Single s = new Single();
privateSingle(){}
publicstatic Single getInstance()
{
returns;
}
}
之所以称为饿汉式是因为Single类一进内存,就已经建立好了对象。
懒汉式代码是:
class Single
{
privatestatic Single s = null;
privateSingle(){}
publicstatic Single getInstance()
{
if(s==null)
s= new Single();
returns ;
}
}
之所以称为懒汉式是Single类进内存对象还没有存在,只用调用了getInstance方法时,才创建对象。
而懒汉式是有安全问题的,因为s是共享数据,如果多个线程并发的访问getInstance方法,那就有可能共同在getInstance方法中操作,比如线程A在判断了s==null后挂起,而这时线程B在判断后也进入了,并一样的挂起。此时A醒了,new一个s对象,在这之后B线程也醒了,也new了一个对象,这就出现问题了,就违背了单例设计模式的初衷了。这就要加入同步锁了。改进后代码如下:
class Single
{
privatestatic Single s = null;
privateSingle(){}
publicstatic Single getInstance()
{
/*加入双重判断模式,提高效率*/
if(s==null)
{
synchronized(Single.class)//这里不能是this,因为静态
{
if(s==null)
s= new Single();
}
}
returns ;
}
}
从以上分析可以看出,饿汉式较懒汉式简单,而且能保证对象的唯一性,所以在实际应用中,还是以饿汉式为主,不建议使用懒汉式。
---------------------- android培训、 java培训、期待与您交流! ----------------------