Java的单例模式实现

简介:

    只能生成一个实例的类是实现了Singleton(单例)模式的类。以下为C#实现单例模式的方式

方式一只使用于单线程环境

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// 把构造函数设为私有函数以禁止他人创建实例
// 定义一个静态的实例,在需要的时候创建该实例
// 在Singleton的静态属性Instance中,只有在instance为null的时候才创建一个实例以避免重复创建
// 把构造函数定义为私有函数
public  final  class  Singleton1 {
     private  Singleton1() {
     }
 
     private  static  Singleton1 _instance =  null ;
 
     public  static  Singleton1 getInstance() {
         if  (_instance ==  null )
             _instance =  new  Singleton1();
         return  _instance;
     }
 
     public  static  void  main(String[] args) {
         Singleton1 s1 = Singleton1.getInstance();
         Singleton1 s2 = Singleton1.getInstance();
 
         System.out.println(s1.hashCode());
         System.out.println(s2.hashCode());
     }
}


方式二 加同步锁

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import  java.util.concurrent.locks.Lock;
import  java.util.concurrent.locks.ReentrantLock;
 
public  final  class  Singleton2 {
     private  Singleton2(){}
     
     static  Lock lock =  new  ReentrantLock();
     
     private  static  Singleton2 _instance =  null ;
     
     public  static  Singleton2 getInstance(){
         lock.lock();
         try  {
             if (_instance ==  null )
                 _instance =  new  Singleton2();
         finally  {
             lock.unlock();
         }
         return  _instance;
     }
 
     public  static  void  main(String[] args) {
         Singleton2 s1 = Singleton2.getInstance();
         Singleton2 s2 = Singleton2.getInstance();
 
         System.out.println(s1.hashCode());
         System.out.println(s2.hashCode());
     }
}


可行的解法 加同步锁前后两次判断实例是否已存在

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
import  java.util.concurrent.locks.Lock;
import  java.util.concurrent.locks.ReentrantLock;
 
public  final  class  Singleton3 {
     private  Singleton3(){}
     
     static  Lock lock =  new  ReentrantLock();
     
     private  static  Singleton3 _instance =  null ;
     
     public  static  Singleton3 getInstance(){
         if (_instance ==  null ){
             lock.lock();
             try {
                 if (_instance ==  null )
                     _instance =  new  Singleton3();
             } finally  {
                 lock.unlock();
             }  
         }
         return  _instance;
     }
 
     public  static  void  main(String[] args) {
         Singleton3 s1 = Singleton3.getInstance();
         Singleton3 s2 = Singleton3.getInstance();
 
         System.out.println(s1.hashCode());
         System.out.println(s2.hashCode());
     }
}


推荐的解法一利用静态构造函数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
public  final  class  Singleton4 {
     private  Singleton4(){}
     
     private  static  Singleton4 _instance =  new  Singleton4();
     
     public  static  Singleton4 getInstance()
     {
         return  _instance;
     }
 
     public  static  void  main(String[] args) {
         Singleton4 s1 = Singleton4.getInstance();
         Singleton4 s2 = Singleton4.getInstance();
 
         System.out.println(s1.hashCode());
         System.out.println(s2.hashCode());
     }
 
}


推荐的解法二 实现按需创建实例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
public  class  Singleton5 {
     private  Singleton5(){}
     
     public  static  Singleton5 getInstance(){
         return  Nested.instance;
     }
     
     private  static  class  Nested{
         private  Nested(){}
         public  static  final  Singleton5 instance =  new  Singleton5();
     }
 
     public  static  void  main(String[] args) {
         Singleton5 s1 = Singleton5.getInstance();
         Singleton5 s2 = Singleton5.getInstance();
 
         System.out.println(s1.hashCode());
         System.out.println(s2.hashCode());
     }
 
}


  1. 扩展 

    定义一个表示总统的类型President可以从该类型继承出FrenchPresident和AmericanPresident等类型。这些派生类型都只能产生一个实例        

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
public  class  President {
     private  String _name;
     
     public  President(){}
     
     public  String getName(){
         return  _name;
     }
     
     public  void  setName(String name){
         _name = name;
     }
     
     public  static  void  main(String[] args) {
     }
 
}
 
public  class  FrenchPresident  extends  President{
     private  FrenchPresident(){}
     
     public  static  FrenchPresident getInstance()
     {
         return  Nested.instance;
     }
     
     private  static  class  Nested{
         private  Nested(){}
         
         public  static  final  FrenchPresident instance =  new  FrenchPresident();
     }
 
     public  static  void  main(String[] args) {
         FrenchPresident s1 = FrenchPresident.getInstance();
         FrenchPresident s2 = FrenchPresident.getInstance();
 
         System.out.println(s1.hashCode());
         System.out.println(s2.hashCode());
 
     }
 
}
 
 
public  class  AmericanPresident {
     private  AmericanPresident() {
     }
 
     public  static  AmericanPresident getInstance() {
         return  Nested.instance;
     }
 
     private  static  class  Nested {
         private  Nested() {
         }
 
         public  static  final  AmericanPresident instance =  new  AmericanPresident();
     }
 
     public  static  void  main(String[] args) {
         AmericanPresident s1 = AmericanPresident.getInstance();
         AmericanPresident s2 = AmericanPresident.getInstance();
 
         System.out.println(s1.hashCode());
         System.out.println(s2.hashCode());
 
     }
 
}



本文转自 许大树 51CTO博客,原文链接:http://blog.51cto.com/abelxu/1965630,如需转载请自行联系原作者
相关文章
|
11月前
|
设计模式 安全 Java
Java编程中的单例模式深入剖析
【10月更文挑战第21天】在Java的世界里,单例模式是设计模式中一个常见而又强大的存在。它确保了一个类只有一个实例,并提供一个全局访问点。本文将深入探讨如何正确实现单例模式,包括常见的实现方式、优缺点分析以及最佳实践,同时也会通过实际代码示例来加深理解。无论你是Java新手还是资深开发者,这篇文章都将为你提供宝贵的见解和技巧。
175 65
|
10月前
|
设计模式 Java 数据库连接
Java编程中的设计模式:单例模式的深度剖析
【10月更文挑战第41天】本文深入探讨了Java中广泛使用的单例设计模式,旨在通过简明扼要的语言和实际示例,帮助读者理解其核心原理和应用。文章将介绍单例模式的重要性、实现方式以及在实际应用中如何优雅地处理多线程问题。
135 4
|
10月前
|
设计模式 安全 Java
Java编程中的单例模式:理解与实践
【10月更文挑战第31天】在Java的世界里,单例模式是一种优雅的解决方案,它确保一个类只有一个实例,并提供一个全局访问点。本文将深入探讨单例模式的实现方式、使用场景及其优缺点,同时提供代码示例以加深理解。无论你是Java新手还是有经验的开发者,掌握单例模式都将是你技能库中的宝贵财富。
305 2
|
10月前
|
设计模式 安全 Java
Java编程中的单例模式深入解析
【10月更文挑战第31天】在编程世界中,设计模式就像是建筑中的蓝图,它们定义了解决常见问题的最佳实践。本文将通过浅显易懂的语言带你深入了解Java中广泛应用的单例模式,并展示如何实现它。
|
12月前
|
设计模式 安全 Java
Java 编程中的设计模式:单例模式的深度解析
【9月更文挑战第22天】在Java的世界里,单例模式就像是一位老练的舞者,轻盈地穿梭在对象创建的舞台上。它确保了一个类仅有一个实例,并提供全局访问点。这不仅仅是代码优雅的体现,更是资源管理的高手。我们将一起探索单例模式的奥秘,从基础实现到高级应用,再到它与现代Java版本的舞蹈,让我们揭开单例模式的面纱,一探究竟。
102 11
|
设计模式 存储 负载均衡
【五】设计模式~~~创建型模式~~~单例模式(Java)
文章详细介绍了单例模式(Singleton Pattern),这是一种确保一个类只有一个实例,并提供全局访问点的设计模式。文中通过Windows任务管理器的例子阐述了单例模式的动机,解释了如何通过私有构造函数、静态私有成员变量和公有静态方法实现单例模式。接着,通过负载均衡器的案例展示了单例模式的应用,并讨论了单例模式的优点、缺点以及适用场景。最后,文章还探讨了饿汉式和懒汉式单例的实现方式及其比较。
【五】设计模式~~~创建型模式~~~单例模式(Java)
|
12月前
|
设计模式 Java 安全
Java设计模式-单例模式(2)
Java设计模式-单例模式(2)
|
10月前
|
设计模式 SQL 安全
Java编程中的单例模式深入解析
【10月更文挑战第24天】在软件工程中,单例模式是设计模式的一种,它确保一个类只有一个实例,并提供一个全局访问点。本文将探讨如何在Java中使用单例模式,并分析其优缺点以及适用场景。
81 0
|
11月前
|
设计模式 SQL 安全
【编程进阶知识】Java单例模式深度解析:饿汉式与懒汉式实现技巧
本文深入解析了Java单例模式中的饿汉式和懒汉式实现方法,包括它们的特点、实现代码和适用场景。通过静态常量、枚举类、静态代码块等方式实现饿汉式,通过非线程安全、同步方法、同步代码块、双重检查锁定和静态内部类等方式实现懒汉式。文章还对比了各种实现方式的优缺点,帮助读者在实际项目中做出更好的设计决策。
287 0
|
设计模式 安全 Java
Java 单例模式,背后有着何种不为人知的秘密?开启探索之旅,寻找答案!
【8月更文挑战第30天】单例模式确保一个类只有一个实例并提供全局访问点,适用于需全局共享的宝贵资源如数据库连接池、日志记录器等。Java中有多种单例模式实现,包括饿汉式、懒汉式、同步方法和双重检查锁定。饿汉式在类加载时创建实例,懒汉式则在首次调用时创建,后者在多线程环境下需使用同步机制保证线程安全。单例模式有助于提高代码的可维护性和扩展性,应根据需求选择合适实现方式。
73 1

热门文章

最新文章