JAVA 单例模式实现-整理

本文详细介绍了Java单例模式的两种实现方式——饿汉单例和懒汉单例,并解释了为何在多线程环境下使用单例模式的重要性。讨论了单例模式的适用场景,如用于频繁访问且需线程安全的对象。文章还分析了单例模式的关键特性及其实现原理,以及在实际开发中如何利用单例模式优化资源管理和提高系统性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JAVA单例模式实现一般分为两种:

/**
  * 饿汉单例模式
  * @return
  */
 private final static TestStream2 ts1 = new TestStream2();
 
 public static TestStream2 getInstance() {
  return ts1;
 }

 

/**
  * 懒汉单例模式
  * @return
  */
 private static TestStream ts1 = null;
 
 public static TestStream getInstance() {
  if (ts1 == null) {
   ts1 = new TestStream();
  }
  return ts1;
 }

 

什么是单例、JAVA中为什么要使用单例:

为什么好多考官都要考单例模式,现将自已的理解做一下简单介绍:其实程序最初的思想是用NEW去创建一个实例对象,然后我们使用这个实例对象去做一些相关的操作,那如果有多个线程同时访问,那意味着要NEW多个实例对象,这样不仅使服务器性能下降,而且占用内存会越来越大,线程越多,占用内存越大。例:当我们需要访问的时候总是需要NEW一个CONNECT实例,然后才能用实例进行增删改的相关操作,然而这对于一个WEB客户端,启动一个线程,在每次访问的时候都会去与服务器后台打交道,这意味着,假如有一万个Web客户端将要启动一万个线程都去访问服务器那将会,NEW一万个实例对象,不公是非常占内存,而且性能也会急剧下降,后果可想而知......,因此优秀的程序员们绞尽脑汁的去优化自已的程序。有人提问:在这一万个WEB客户端线程间,是否能将CONNECT只用一个实例,让每一个WEB客户端都去访问这个连接?答案就是单例。如果我们创建一个单例程序,然后在服务器启动后,自始自终,服务器只对某个类进行一次实例,这就是单例。它不仅能节省服务器的内存,也能提高服务器的性能。如果平凡的使用NEW也会耗相当大的内存,所以在能够多个线程之间共用一个对象的时候,尽量用单例模式去实现该程序。SPRING是我们每个人都非常熟知的开源框架。SPRING中大量使用了单例去初始化一些BEAN。这使得我们N多WEB客户端在请求的时候不需要在NEW一些东西,只需要去得到单例的对象去操作,就可以了,它的依赖注入也只是将这些单例的实例对象得到然后进行注入到另一个对象,进行使用。

 

单例其一;它们必须自行初始化,这是其二;允许整个系统访问自己这是其三。因此,它们都满足单例模式的条件,是单例模式的应用。

当一个类的实例可以有且只可以一个的时候就需要用到了。为什么只需要有一个呢?有人说是为了节约内存。本人对这个说法持保留态度。只有一个实例确实减少内存占用,可是我认为这不是使用单例模式的理由。我认为使用单例模式的时机是当实例存在多个会引起程序逻辑错误的时候。比如类似有序的号码生成器这样的东西,怎么可以允许一个应用上存在多个呢?Singleton模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在。

 

一般什么时候使用单例模式呢?

答:一般来说,当某个对象会被频繁访问并且在多线程并发访问时没有线程安全性的问题时,可以考虑使用单例工厂来完成这样的任务,比如DAO类Service类等等这样需要被大量访问的对象。

 

以上整理自网络!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值