「单例模式java实现懒汉」java单机模式懒汉
本篇文章给大家谈谈单例模式java实现懒汉,以及java单机模式懒汉对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
java中,请写单例模式,饿反式,懒汉式,并说明使用场合!
是饿汉式吧,希望对你有用,单例模式其实就是构造方法是私有的,通过getInstance()来取得实例。
package cn.ineeke.util;
/**
* 单利模式——懒汉式
* @author Neeke
*
*/
public class DB {
private static DB db = null;
public static DB getInstance(){
if(db == null){
db = new DB();
}
return db;
}
}
package cn.ineeke.util;
/**
* 单利模式——饿汉式
* @author Neeke
*
*/
public class DB {
private static DB db = new DB();
public static DB getInstance(){
return db;
}
}
这种静态初始化的方法是自己被加载时就自己实例化,被形象的称之为饿汉式单例类。而原先的单例模式处理方式要在第一次被引用的时候才会被实例化,就被称为懒汉式单例类。
由于在多线程访问时懒汉式可能会出现创建出多个实例,而若对其使用synchronized的话,则又会降低程序性能。所以推荐使用饿汉式。
单例模式懒汉式与饿汉式详解
单例模式属于创建型模式的一种,应用于保证一个类仅有一个实例的场景下,并且提供了一个访问它的全局访问点,如spring中的全局访问点BeanFactory,spring下所有的bean都是单例。
单例模式的特点:从系统启动到终止,整个过程只会产生一个实例。
单例模式常用写法:懒汉式,饿汉式,注册式,序列化式。
下面比较一下懒汉式和饿汉式:
懒汉式:默认不会实例化,什么时候用什么时候new。
饿汉式:类加载的时候就实例化,并且创建单例对象。
实例化方面: 懒汉式默认不会实例化,外部什么时候调用什么时候new。饿汉式在类加载的时候就实例化,并且创建单例对象。
线程安全方面: 饿汉式线程安全 (在线程还没出现之前就已经实例化了,因此饿汉式线程一定是安全的)。懒汉式线程不安全( 因为懒汉式加载是在使用时才会去new 实例的,那么你去new的时候是一个动态的过程,是放到方法中实现的,比如:public static synchronized Lazy getInstance(){ if(lazy==null){ lazy=new Lazy(); } 如果这个时候有多个线程访问这个实例,这个时候实例还不存在,还在new,就会进入到方法中,有多少线程就会new出多少个实例。一个方法只能return一个实例,那最终return出哪个呢?是不是会覆盖很多new的实例?这种情况当然也可以解决,那就是加同步锁,避免这种情况发生) 。
执行效率上: 饿汉式没有加任何的锁,因此执行效率比较高。懒汉式一般使用都会加同步锁,效率比饿汉式差。
性能上: 饿汉式在类加载的时候就初始化,不管你是否使用,它都实例化了,所以会占据空间,浪费内存。懒汉式什么时候需要什么时候实例化,相对来说不浪费内存。
java 单例模式
System.out.println (Singleton.getInstance());
System.out.println (Singleton.getInstance());
main 函数中有这两句,一摸一样。
第一句执行的时候,第一次调用getInstance(),意思是要获取Singleton的一个对象实例。
而正常情况下,我们要获取对象的话是用 new Singleton(),这个方法的,但是这个方法在Singleton里面被声明为:private ,意思是外界不能调用。
不能调用,我怎么用你的对象?
Singleton里面实现了生成对象的方法,getInstance(),你要用他的对象就必须调用这个方法。
而这个方法里面你也看到了,如果
if(instance == null){
instance = new Singleton();
}
如果没有实例则创建一个新的,但是已经创建过的话,就返回已经存在的实例。
所以输出结果:
net.chelson.chapter5.Singleton@de6ced
net.chelson.chapter5.Singleton@de6ced
你两次调用的这个对象的内存地址都是相同的,也就是说,是同一个东西(对象)
这个总的来说就是:
类的构造方法私有化(防止外界构造新对象)
提供获取实例的方法(用于外界调用)
作用:用于提供只能有一个实例的对象。
java常用的几种单例模式(懒汉式,饿汉式
单件模式用途:
单件模式属于工厂模式的特例,只是它不需要输入参数并且始终返回同一对象的引用。
单件模式能够保证某一类型对象在系统中的唯一性,即某类在系统中只有一个实例。它的用途十分广泛,打个比方,我们开发了一个简单的留言板,用户的每一次留言都要将留言信息写入到数据库中,最直观的方法是没次写入都建立一个数据库的链接。这是个简单的方法,在不考虑并发的时候这也是个不错的选择。但实际上,一个网站是并发的,并且有可能是存在大量并发操作的。如果我们对每次写入都创建一个数据库连接,那么很容易的系统会出现瓶颈,系统的精力将会很多的放在维护链接上而非直接查询操作上。这显然是不可取的。
如果我们能够保证系统中自始至终只有唯一一个数据库连接对象,显然我们会节省很多内存开销和cpu利用率。这就是单件模式的用途。当然单件模式不仅仅只用于这样的情况。在《设计模式:可复用面向对象软件的基础》一书中对单件模式的适用性有如下描述:
1、当类只能有一个实例而且客户可以从一个众所周知的访问点访问它时。
2、当这个唯一实例应该是通过子类化可扩展的,并且客户应该无需更改代码就能使用一个扩展的实例时。
下面对单件模式的懒汉式与饿汉式进行简单介绍:
1、饿汉式:在程序启动或单件模式类被加载的时候,单件模式实例就已经被创建。
2、懒汉式:当程序第一次访问单件模式实例时才进行创建。
如何选择:如果单件模式实例在系统中经常会被用到,饿汉式是一个不错的选择。
单例模式java实现懒汉的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于java单机模式懒汉、单例模式java实现懒汉的信息别忘了在本站进行查找喔。
发布于:2022-12-10,除非注明,否则均为
原创文章,转载请注明出处。