单例解决了什么问题:为了节约系统资源,有时需要确保系统中某个类只有唯一一个实例,当这个唯一实例创建成功之后,我们无法再创建一个同类型的其他对象,所有的操作都只能基于这个唯一实例。为了确保对象的唯一性,我们可以通过单例模式来实现,这就是单例模式的动机所在。

单例的应用场景:一般是对于那些业务逻辑上限定不能多例只能单例的情况,例如:类似于计数器之类的存在,一般都需要使用一个实例来进行记录,若多例计数则会不准确。

饿汉式:

  条件:

  1. 构造器私有化
  2. 本类对象作为本类的属性存在 用static 修饰保证只加载一次,不会重复创建对象
  3. 公共的静态的方法可以通过该方法拿到属性

  优缺点:

    优点:安全

    缺点:可能会导致对象创建过早

 package com.设计模式;

 /**
  * 饿汉式
  */
 public class ObjectShow1 {
     public static int i = 123;
     //静态私有成员,类在加载初期完成初始化;同时带来加载过早的问题
     private static ObjectShow1 objectShow1 = new ObjectShow1();

     private ObjectShow1() {
         //私有构造函数,只能被列对象初始化
         System.out.println(i);
     }

     //使用public对外开放获取本类对象
     public static ObjectShow1 getObjectShow1() {
         return objectShow1;
     }
 }

懒汉式:

条件:

  1. 构造器私有化
  2. 本类对象作为本类的属性存在 static 修饰 但是不进行初始化
  3. 公共的静态方法 并且判断是否给属性赋值

优缺点:

    优点:对象总是被需要的时候才被创建 解决了可能加载时机过早的问题

    缺点:在线程初期 线程不安全

 package com.设计模式;

 /**
  * 懒汉式
  */
 public class ObjectShow2 {
     public static int i = 123;
     //静态私有成员,不用构造器进行初始化
     private static ObjectShow2 objectShow2 = null;

     private ObjectShow2() {
         //私有构造函数,只能被列对象初始化
         System.out.println(i);
     }

     //使用public对外开放获取本类对象,只有调用方法才会进行初始化
     public static ObjectShow2 getObjectShow2() {
         if (objectShow2 == null) {
             objectShow2 = new ObjectShow2();
         }
         return objectShow2;
     }
 }

双重检索式:

条件:

1.构造器私有化

2.本类的对象作为奔雷的属性存在 static 修饰 但不进行初始化

3.公共的静态方法 并且判断是否给属性赋值

优缺点:

    程序的前期 线程不安全

    Synchronized 锁

    Synchronized 代码块 要求同一时间只有一个线程进入代码块区域

    因为jvm内存模型的原因 双重检索 也会有微小的可能发生问题

 package com.设计模式;

 /**
  * 双重检索式
  */
 public class ObjectShow3 {
     public static int i = 123;
     //静态私有成员,不用构造器进行初始化
     private static ObjectShow3 objectShow3;

     private ObjectShow3() {
         //私有构造函数,只能被列对象初始化
         System.out.println(i);
     }

     //使用public对外开放获取本类对象,只有调用方法才会进行初始化
     public static ObjectShow3 getObjectShow3() {
         if (objectShow3 == null) {
             //同步块,线程安全的创建实例
             synchronized (ObjectShow3.class) {
                 //再次检查实例是否存在,不在才创建
                 if (objectShow3 == null)
                     objectShow3 = new ObjectShow3();
             }
         }
         return objectShow3;
     }
 }

静态内部类式:

条件:

1.定义一个静态内部类

2.外部类构造器私有化

3.外部类的对象 作为内部类的属性存在 static 修饰 进行初始化

4.公共的静态方法

优缺点:

    解决了,对象创建时机过早的问题

    没有产生线程安全问题

 package com.设计模式;

 /**
  * 静态内部类式
  */
 public class ObjectShow4 {
     public static int i = 123;

     static class InitObjectShow {
         private static ObjectShow4 os = new ObjectShow4();

         public static ObjectShow4 getObj() {
             return os;
         }
     }

     private ObjectShow4() {
         System.out.println("ObjectShow4.ObjectShow4");
     }

     public void show() {
         System.out.println("ObjectShow4.show");
     }
 }

Java 设计模式-【单例模式】的更多相关文章

  1. java设计模式单例模式 ----懒汉式与饿汉式的区别

    常用的五种单例模式实现方式 ——主要: 1.饿汉式(线程安全,调用率高,但是,不能延迟加载.) 2.懒汉式(线程安全,调用效率不高,可以延时加载.) ——其他: 1.双重检测锁式(由于JVM底层内部模 ...

  2. Java设计模式の单例模式

    -------------------------------------------------- 目录 1.定义 2.常见的集中单例实现 a.饿汉式,线程安全 但效率比较低 b.单例模式的实现:饱 ...

  3. JAVA设计模式-单例模式(Singleton)线程安全与效率

    一,前言 单例模式详细大家都已经非常熟悉了,在文章单例模式的八种写法比较中,对单例模式的概念以及使用场景都做了很不错的说明.请在阅读本文之前,阅读一下这篇文章,因为本文就是按照这篇文章中的八种单例模式 ...

  4. Java设计模式 - - 单例模式 装饰者模式

    Java设计模式 单例模式 装饰者模式 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 静态代理模式:https://www.cnblogs.com/StanleyBlogs/p/1 ...

  5. 【设计模式】Java设计模式 - 单例模式

    [设计模式]Java设计模式 - 单例模式 不断学习才是王道 继续踏上学习之路,学之分享笔记 总有一天我也能像各位大佬一样 分享学习心得,欢迎指正,大家一起学习成长! 原创作品,更多关注我CSDN: ...

  6. Java 设计模式 —— 单例模式

    1. 概念: 单例模式是一种常用的软件设计模式.核心结构中只包含一个被称为单例的特殊类.通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问,从而方便对实例个数的控制并节约系统资源.如果 ...

  7. Java设计模式 - 单例模式 (懒汉方式和饿汉方式)

    概念: Java中单例模式是一种常见的设计模式,单例模式的意思就是只有一个实例.单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例.这个类称为单例类. 单例模式的写法有好几种,这 ...

  8. java设计模式——单例模式(一)

    一. 定义与类型 定义:保证一个类仅有一个实例,并提供一个全局访问点 类型:创建型 二. 适用场景 想确保任何情况下都绝对只用一个实例 三. 优缺点 优点: 在内存里只有一个实例,减少了内存开销 可以 ...

  9. JAVA设计模式--单例模式

    单例设计模式 Singleton是一种创建型模式,指某个类采用Singleton模式,则在这个类被创建后,只可能产生一个实例供外部访问,并且提供一个全局的访问点. 核心知识点如下: (1) 将采用单例 ...

  10. Java设计模式-单例模式(Singleton)

    单例对象(Singleton)是一种常用的设计模式.在Java应用中,单例对象能保证在一个JVM中,该对象只有一个实例存在.这样的模式有几个好处: 1.某些类创建比较频繁,对于一些大型的对象,这是一笔 ...

随机推荐

  1. PCB学习

    一.PCB设置 在线DRC:自动更正,会提示短路. 对象捕捉>>智能元件snap,可以智能抓取中心点,勾选 智能TrackEnds: 撤销重做:30步 旋转步骤:90.000(可以按空格旋 ...

  2. Oracle or Question Solve(二)

    数据库常用语句和函数 ----update update()函数主要注意的是后面的where限制条件--例子:update tab_a a set a.v1 = (select b.v1 from t ...

  3. 防止NSTimer和调用对象之间的循环引用

    防止NSTimer和调用对象之间的循环引用 @interface NSTimer (EOCBlocksSupport) + (NSTimer *)eoc_scheduledTimerWithTimeI ...

  4. 120、TensorFlow创建计算图(二)

    #创建一个计算流图 #大多数tensorflow程序开始于dataflow graph 的构造函数 #在这个命令中你执行了tensorflow api的函数 #创建了新的操作tf.Operation ...

  5. Python 进阶_闭包 & 装饰器

    目录 目录 闭包 函数的实质和属性 闭包有什么好处 小结 装饰器 更加深入的看看装饰器的执行过程 带参数的装饰器 装饰器的叠加 小结 装饰器能解决什么问题 小结 闭包 Closure: 如果内层函数引 ...

  6. 关于Http请求Cookie问题

    在Http请求中,很多时候我们要设置Cookie和获取返回的Cookie,在这个问题上踩了一个很大的坑,主要是两个问题: 1.不能获取到重定向返回的Cookie: 2.两次请求返回的Cookie是相同 ...

  7. python3项目打包成exe可执行程序

    使用pyinstaller将python文件打包成exe程序,打包步骤如下: 一.安装pyinstaller (1)win+R输入cmd,打开命令窗口 (2)安装pyinstaller,安装指令:pi ...

  8. hdu3518 Boring counting(后缀数组)

    Boring counting 题目传送门 解题思路 后缀数组.枚举每种长度,对于每个字符串,记录其最大起始位置和最小起始位置,比较是否重合. 代码如下 #include <bits/stdc+ ...

  9. leetcode.图.785判断二分图-Java

    1. 具体题目 给定一个无向图graph,当这个图为二分图时返回true.如果我们能将一个图的节点集合分割成两个独立的子集A和B,并使图中的每一条边的两个节点一个来自A集合,一个来自B集合,我们就将这 ...

  10. spark streaming 笔记

    spark streaming项目 学习笔记 为什么要flume+kafka? 生成数据有高峰与低峰,如果直接高峰数据过来flume+spark/storm,实时处理容易处理不过来,扛不住压力.而选用 ...