单例模式之懒汉模式&恶汉模式

单例模式,其实就是对于一个类,只能新建一个对象,不能有多个重复的对象。这样使得在程序在运行时,比如日志加载时能找到唯一的对象,以至正确匹配。就类似于一山不能有二虎一样。主要的思想其实就是运用static,在类内部new一个自己的对象,再通过类方法返回这个对象。由于静态方法new出的对象,故其实有着同样的hashCode,也即同一个对象。一下是代码:

  1. Test.java
package com.demo_type;

public class Test {
	public static void main(String[] args){

		//饿汗模式
		Singleton s1 = Singleton.getInstance();
		Singleton s2 = Singleton.getInstance();

		if(s1 == s2){
			System.out.println("s1 = s2");
		}
		else{
			System.out.println("s1 != s2");
		}
		//懒汉模式
		Singleton2 s3 = Singleton2.getInstance();
		Singleton2 s4 = Singleton2.getInstance();
		if(s3 == s4){
			System.out.println("s3 and s4 is the same");
		}
		else{
			System.out.println("s3 and s4 is NOT the same");
		}

	}
}

2.Singleton.java

package com.demo_type;

/**
 * @author YBnew
 * 单例模式Singleton
 * 应用场合:有些对象只需要一个就足够了,如皇帝
 * 作用: 保证整个应用程序中某个实例有且只有一个
 */
public class Singleton {
	//1.将构造方法私有化,不允许外部直接创建对象
	private Singleton(){

	}
    //2.自己创建一个类的唯一实例
	//3.将其便为static(如果将其设为private,更符合封装)
	private static Singleton instance = new Singleton();

	public static Singleton getInstance(){
		return instance;
	}
}

3.Singleton2.java

package com.demo_type;

/**
 * @author YBnew
 * 懒汉模式
 * 区别: 饿汉模式的特点是加载类时比较慢,但运行是比较快-线程安全
 * 	    懒汉模式的特点是加载类时比较快,但运行时比较慢-线程不安全
 */
public class Singleton2 {
	//1.将构造函数私有化,不允许外部直接创建对象
	private Singleton2(){

	}
	//2.声明类的唯一实例,使用private static 修饰
	private static Singleton2 instance;

	//3.判断一下,也即运行时加载
	public static Singleton2 getInstance(){
//		if(instance == null){
//			return new Singleton2();
//		}
//		else{
//			return instance;
//		}
		if(instance == null){
			instance = new Singleton2();
		}
			return instance;
	}
}

懒汉模式和饿汉模式的取名也比较容易理解,因为懒汉模式在类加载时就已经new出了对象,这种模式new对象很着急,

而懒汉就你需要的时候再new,不紧不慢的。

单例模式之懒汉模式&恶汉模式

时间: 2024-08-12 12:00:47

单例模式之懒汉模式&恶汉模式的相关文章

单例模式之懒汉模式,懒汉模式之高效模式,DLC双判断模式

import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit; /** * 单例模式之懒汉模式 * 懒汉模式之高效模式 * DLC双判断模式 */ public class SingleClassLazySync { private static SingleClassLazySync sin

单例模式(懒汉方式和饿汉方式)

Singleton 单例模式(懒汉方式和饿汉方式) 单例模式的概念: 单例模式的意思就是只有一个实例.单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例.这个类称为单例类. 关键点: 1)一个类只有一个实例       这是最基本的 2)它必须自行创建这个实例 3)它必须自行向整个系统提供这个实例 -----------------------------------------------------------------------------------------

javascript单例模式(懒汉 饿汉)

第一种:懒汉模式 var Singleton=(function(){ var instantiated; //比较懒,在类加载时,不创建实例,因此类加载速度快,但运行时获取对象的速度慢 function init(){ /*这里定义单例代码*/ return{ publicMethod:function(){ console.log('helloworld'); }, publicProperty:3 }; } return{ getInstance:function(){ if(!insta

设计模式-行为型模式-策略模式

策略模式 在实际工作中我用到了策略模式,但为什么要有环境角色呢? 这里我贴上英文对含义的介绍, The Strategy Pattern defines a family of algorithms,encapsulates each one,and makes them interchangeable. Strategy lets the algorithm vary independently from clients that use it. 然后看看这种设计模式的组成, 一般的,策略模式

第22章 行为型模式—状态模式

1. 状态模式(State Pattern)的定义 (1)定义:允许一个对象在其内部状态改变时改变它的行为.对象看起来似乎修改了它的类. ①状态和行为,它们的关系可以描述为“状态决定行为” ②因状态是在运行期被改变,行为也会在运行期根据状态的改变而改变.看起来,同一个对象,在不同的运行时刻,行为是不一样的,就像是类被修改了一样. (2)状态模式的结构和说明 ①Context:环境,也称上下文,通常用来定义客户感兴趣的接口,同时维护一个来具体处理当前状态的实例对象. ②State:状态接口,用来封

设计模式笔记:状态模式&策略模式

这几天一直在忙期末考和实训,写笔记的时间也没有多少,不说废话了: 这文主要写两种模式:状态跟策略,主要是因为他们的类图一样,并且比较简单,写在同一篇文章里面容易甄别 状态模式:允许对象在内部状态改变时改变他的行为,对象看起来好像修改了他的类 先保留概念的意思,在平常的编程中,如果需要不同的状态,很一般的做法是在你要操作的类里面定义不同的常量代表不同的状态,然后if-else依据不同的状态有不同的实现: 1.你可以想象大量的if-else语句造成的低可读性和低效率 2.其次是你修改这个类的时候很麻

Java设计模式(十) 备忘录模式 状态模式

(十九)备忘录模式 备忘录模式目的是保存一个对象的某个状态,在适当的时候恢复这个对象. class Memento{ private String value; public Memento(String value){ this.value = value; } public String getValue() { return value; } public void setValue(String value) { this.value = value; } } class Storage

专用服务器模式&共享服务器模式

连接ORACLE服务器一般有两种方式:专用服务器连接(dedicated server)和共享服务器连接(shared server).那么两者有啥区别和不同呢?下面我们将对这两者的区别与不同一一剖析. 专用服务器模式(dedicated server)模式 在专用服务器模式中,用户进程运行在客户端的机器上,专用服务器进程运行在数据库服务器,用户进程和专用服务器进程是两种不同类型的进程. 对于专用服务器模式,在用户登录时,ORACLE总会创建一个新的服务进程,这通常称为专用服务器配置.这个服务器

Handler+ExecutorService(线程池)+MessageQueue模式+缓存模式

android线程池的理解,晚上在家无事 预习了一下android异步加载的例子,也学习到了一个很重要的东东 那就是线程池+缓存  下面看他们的理解. [size=1.8em]Handler+Runnable模式 我们先看一个并不是异步线程加载的例子,使用 Handler+Runnable模式. 这里为何不是新开线程的原因请参看这篇文章:Android Runnable 运行在那个线程 这里的代码其实是在UI 主线程中下载图片的,而不是新开线程. 我们运行下面代码时,会发现他其实是阻塞了整个界面