Spring -11 -单例设计模式 -懒汉式/饿汉式(idea默认的)

单例设计模式

  1. 作用: 在应用程序有保证最多只能有一个实例.
  2. 好处:

  2.1 提升运行效率.

  2.2 实现数据共享. 案例:application 对象

    1. 懒汉式

  3.1 对象只有被调用时才去创建.

  3.2  示例代码

3.3由于添加了锁,所以导致效率低.

public class lazySingleton {  //懒汉式,单例模式!
    //由于对象需要被静态方法调用,把方法设置为static
    //由于对象是static,必须要设置访问权限修饰符为private ,
//如果是public 可以直接调用对象,不执行访问入口
    private static lazySingleton ourInstance ;
 /**
    *方法名和类名相同,无返回值.
    *其他类不能实例化这个类对象;对外提供访问入口
    */

    private lazySingleton() {
    }
/**

*实例方法,实例方法必须通过对象调用

*设置方法为静态方法
*@return 一个上面的static 对象

*/
    public static lazySingleton getInstance() {
    //添加逻辑如果实例化过,直接返回
        if(ourInstance==null){
         /*
         * 多线程访问下,可能出现if 同时成立的情况,添加锁;
          监控这个类下创建一个锁,每次只允许一个class进入;
         */
            synchronized (lazySingleton.class){
                if(ourInstance==null){ //双重验证
                    ourInstance =new lazySingleton();
                }
            }
        }
        return ourInstance;
    }

}

3.4 测试

  

        lazySingleton singleton = lazySingleton.getInstance();
        lazySingleton singleton1 = lazySingleton.getInstance();
        System.out.println(singleton==singleton1);
        System.out.println(singleton);
        System.out.println(singleton1);

--------------------
true
[email protected]
[email protected]

4.饿汉式  (IDEA 编译器默认的singleTon)
  解决了懒汉式中多线程访问可能出现同一个对象和效率低问题 ,多个实例共用一个对象!

public class hungerSingleton {
    private static hungerSingleton ourInstance = new hungerSingleton();

    public static hungerSingleton getInstance() {
        return ourInstance;
    }

    private hungerSingleton() {
    }
}

原文地址:https://www.cnblogs.com/zhazhaacmer/p/10113952.html

时间: 2024-10-11 13:01:46

Spring -11 -单例设计模式 -懒汉式/饿汉式(idea默认的)的相关文章

单例设计模式---懒汉式+饿汉式

package com.Thread; /** * 单例设计模式:确保一个类只有一个对象 */ public class Synchronized_Singleton { public static void main(String[] args) { JvmThread jvm1= new JvmThread(100); JvmThread jvm2= new JvmThread(100); jvm1.start(); jvm2.start(); } } /** * 懒汉式(饿汉式:在声明静态

单例设计模式之饿汉式(静态常量)

package com.waibizi; /** * 单例设计模式之饿汉式(静态常量) * 步骤 * 1.构造器私有化(防止new) * 2.类的内部创建对象 * 3.向外暴露一个静态的公共方法 getInstance * 4.代码实现 * @author 歪鼻子 * * *优点:这种写法比较简单,类加载的时候就完成了实例化.避免了线程同步问题 *缺点:类装载的时候就完成了实例化,如果从开始到至终都没使用过这个类,势必会造成资源的浪费 *结论:这种单例模式是可用的,可能会导致浪费(调用getIn

单例设计模式之饿汉式(静态代码块)

package com.waibizi.demo02; /** * 单例设计模式之饿汉式(静态代码块) * 这种方式与饿汉式静态常量的方式是类似的,类装载的时候也有直接创建对象 * @author 歪鼻子 * */ @SuppressWarnings("all") public class Singleton_Pattern { public static void main(String[] args) { // TODO Auto-generated method stub } }

单例设计模式之饿汉式与懒汉式

/* 设计模式:对问题行之有效的解决方式.其实它是一种思想. 1,单例设计模式. 解决的问题:就是可以保证一个类在内存中的对象唯一性. 必须对于多个程序使用同一个配置信息对象时,就需要保证该对象的唯一性. 如何保证对象唯一性呢? 1,不允许其他程序用new创建该类对象. 2,在该类创建一个本类实例. 3,对外提供一个方法让其他程序可以获取该对象. 步骤: 1,私有化该类构造函数. 2,通过new在本类中创建一个本类对象. 3,定义一个公有的方法,将创建的对象返回. */ //饿汉式 class

单例设计模式懒汉式和恶汉式

一,单例设计模式懒汉式和恶汉式 懒汉式在类加载时不初始化,延迟加载.(配置文件) 饿汉式在类加载时初始化,加载慢,获取对象快. 饿汉式是线程安全的, 懒汉式需要加synchronized,否则不安全. 二,饿汉式 1 public class Singletonehan { 2 private static Singletonehan singleton=new Singletonehan(); 3 private Singletonehan() { 4 } 5 public static Si

java===单类设计模式之饿汉式与懒汉式

package cn.china; public class Single { public static void main(String[]args){ // S singles=S.getInstance(); // S singless=S.getInstance(); // System.out.println(singles==singless); Test tt=Test.getInstance(); Test ttt=Test.getInstance(); tt.setNum(1

Java---15---单例设计模式:---饿汉式和懒汉式

概念: 单例模式确保某个类只有一个实例,而且自行实例化并向整个系统提供这个实例.   单例模式有以下特点: 1.单例类只能有一个实例 2.单例类必须自己给自己创建自己的唯一实例 3.单例类必须给所有其他对象提供这一实例 饿汉式: /*饿汉式*/ class Single { private static final Single s = new Single(); private Single () {} public static Single getInstance() { return s

设计模式中饿汉式单例类和懒汉式单例类

单例模式的特点为: *单例类只有一个实例. *单例类必须自己创建自己的唯一实例. *单例类必须给所有其他对象提供这一实例. 饿汉式单例类: 而饿汉式单例类则在java语言中是最为简单的单例类,这是一个描述饿汉式单例类的类图的实现. 此类图中,此类已经将自己实例化. 源码为: package singleton; public class EagerSingleton { private static EagerSingleton instance=new EagerSingleton(); /*

单例设计模式懒汉式的缺陷

http://icyfenix.iteye.com/blog/575052 IcyFenix 探索设计模式之六——单例模式 设计模式Spring应用服务器多线程JVM 6.单例模式(Singleton Pattern) 前面说提到的五种创建模式,主要解决的问题是如何创建对象,获得产品.而单例模式最要关心的则是对象创建的次数以及何时被创建. Singleton模式可以是很简单的,它的全部只需要一个类就可以完成(看看这章可怜的UML图).但是如果在“对象创建的次数以及何时被创建”这两点上较真起来,S