zoukankan      html  css  js  c++  java
  • 最简单的单例模式


      如果一个类始终只能创建一个实例,则这个类被称为单例类。

      在一些特殊的场景下,要求不允许自由创建该类的对象,而是只允许为该类创建一个对象。为了避免其他类自由创建该类的实例,我们把该类的构造器使用private修饰,从而把该类的所有构造器隐藏起来。

      根据良好封装的原则:一单把该类的构造器隐藏起来,则需要提供一个public方法作为该类的访问点,用于创建该类的对象,且该方法必须使用static修饰(因为调用该方法之前还不存在对象,因此调用该方法的不可能是对象,只能是类)。

      除此之外,该类还必须缓存已经创建的对象,否则该类无法知道是否曾经创建过对象,也就无法保证只创建一个对象。为此该类需要使用一个属性来保存曾经创建的对象,因为该属性需要被上面的静态方法访问,故该属性必须使用static修饰。

      基于上面的介绍,下面程序创建了一个单例类。

      程序如下:

      

    复制代码
     1 class  Singleton
     2 {
     3     //使用一个变量来缓存曾经创建的实例
     4     private static Singleton instance;
     5     //讲构造器用private来修饰,隐藏该构造器
     6     private Singleton(){};
     7     //提供一个静态方法,用于返回Singleton实例
     8     //该方法可以加入自定义的控制,保证只产生一个Singleton对象
     9     public static Singleton getIntance()
    10     {
    11         //如果instance为null,表明还不曾创建Singleton对象
    12         //如果instance不为null,则表明已经创建了Singleton对象,将不会执行该方法
    13         if(instance==null)
    14         {
    15             //创建一个Singleton对象,并将其缓存起来
    16             instance=new Singleton();
    17         }
    18         return instance;
    19     
    20     }
    21     
    22 }
    23 
    24 // 测试代码
    25 public class TestSingleton
    26 {
    27     public static void main(String[] args) 
    28     {
    29         //创建Singleton对象不能通过构造器,只能通过getInstance的方法
    30         Singleton s1=Singleton.getInstance();
    31         Singleton s1=Singleton.getInstance();
    32         //将输出true
    33         System.out.println(s1==s2);
    34     }
    35 }
  • 相关阅读:
    浏览器内置对象及其方法
    Leetcode | Path Sum I && II
    Leetcode | 3Sum
    算法分析之渐近符号
    Leetcode | Two Sum
    Leetcode | Wildcard Matching
    LeetCode | Regular Expression Matching
    Leetcode | Subsets I & II
    Leetcode | Populating Next Right Pointers in Each Node I & II
    爱是恒久忍耐,又有恩慈
  • 原文地址:https://www.cnblogs.com/baiduligang/p/4247542.html
Copyright © 2011-2022 走看看