希望只生成某个类的一个对象的时候,可以使用该模式来定义类。
如:线程池,日志记录,设备驱动等
[b]一、单线程[/b]
示例代码:
class Singleton{
private static Singleton sl;
private Singleton(){}
public static Singleton getInstance(){
if(sl == null){
sl=new Singleton();
}
return sl;
}
}
public class SingletonTest{
public static void main(String[] args){
Singleton s1=Singleton.getInstance();
Singleton s2=Singleton.getInstance();
if(s1==s2)
System.out.println("Same!");
}
}
执行结果:
C:\javastudy>java SingletonTest
Same!
C:\javastudy>
[b]二、多线程[/b]
如果该类用于多线程,那么需要对前面的程序加以改造,也就是让它保证线程安全。
示例代码1:
[color=red]当多个线程同时执行时,保证不会有两个线程同时进入getInstance方法,从而也就保证了多线程的情况下,也只会生成一个Singleton类的实例。[/color]
class Singleton{
private static Singleton sl;
private Singleton(){}
public static [color=red]synchronized [/color]Singleton getInstance(){
if(sl == null){
sl=new Singleton();
}
return sl;
}
}
public class SingletonTest{
public static void main(String[] args){
Singleton s1=Singleton.getInstance();
Singleton s2=Singleton.getInstance();
if(s1==s2)
System.out.println("Same!");
}
}
执行结果:
C:\javastudy>java SingletonTest
Same!
C:\javastudy>
[color=red]还有一种方法,不用通过synchronized也能保证线程安全。
因为sl是static型的,所以JVM在装载Singleton类的时候就会创建实例。
从而个线程调用getInstance方法时,只是返回相同的句柄而已,从而实现了线程安全的目的。不过这种方法总是会创建Singleton类的一个实例。因为类一被加载就会创建一个实例。[/color]
示例代码2:
class Singleton{
private static Singleton sl=new Singleton();
private Singleton(){}
public static Singleton getInstance(){
return sl;
}
}
public class SingletonTest2{
public static void main(String[] args){
Singleton s1=Singleton.getInstance();
Singleton s2=Singleton.getInstance();
if(s1==s2)
System.out.println("Same!");
}
}
执行结果:
C:\javastudy>java SingletonTest2
Same!
C:\javastudy>
如:线程池,日志记录,设备驱动等
[b]一、单线程[/b]
示例代码:
class Singleton{
private static Singleton sl;
private Singleton(){}
public static Singleton getInstance(){
if(sl == null){
sl=new Singleton();
}
return sl;
}
}
public class SingletonTest{
public static void main(String[] args){
Singleton s1=Singleton.getInstance();
Singleton s2=Singleton.getInstance();
if(s1==s2)
System.out.println("Same!");
}
}
执行结果:
C:\javastudy>java SingletonTest
Same!
C:\javastudy>
[b]二、多线程[/b]
如果该类用于多线程,那么需要对前面的程序加以改造,也就是让它保证线程安全。
示例代码1:
[color=red]当多个线程同时执行时,保证不会有两个线程同时进入getInstance方法,从而也就保证了多线程的情况下,也只会生成一个Singleton类的实例。[/color]
class Singleton{
private static Singleton sl;
private Singleton(){}
public static [color=red]synchronized [/color]Singleton getInstance(){
if(sl == null){
sl=new Singleton();
}
return sl;
}
}
public class SingletonTest{
public static void main(String[] args){
Singleton s1=Singleton.getInstance();
Singleton s2=Singleton.getInstance();
if(s1==s2)
System.out.println("Same!");
}
}
执行结果:
C:\javastudy>java SingletonTest
Same!
C:\javastudy>
[color=red]还有一种方法,不用通过synchronized也能保证线程安全。
因为sl是static型的,所以JVM在装载Singleton类的时候就会创建实例。
从而个线程调用getInstance方法时,只是返回相同的句柄而已,从而实现了线程安全的目的。不过这种方法总是会创建Singleton类的一个实例。因为类一被加载就会创建一个实例。[/color]
示例代码2:
class Singleton{
private static Singleton sl=new Singleton();
private Singleton(){}
public static Singleton getInstance(){
return sl;
}
}
public class SingletonTest2{
public static void main(String[] args){
Singleton s1=Singleton.getInstance();
Singleton s2=Singleton.getInstance();
if(s1==s2)
System.out.println("Same!");
}
}
执行结果:
C:\javastudy>java SingletonTest2
Same!
C:\javastudy>