单例模式的简单分析

第一次写东西,文体形式槽点多多,欢迎指正。

本文旨在交流学习,欢迎大神拍砖。

单例模式是设计模式中比较简单的一个,学习起来比较容易理解。下面开始聊聊各种场景下的单例模式。

单例模式的定义:     一个类有且仅有一个实例,并且自行实例化向整个系统提供。
单例模式的要素: 1.私有的静态的实例对象 2.私有的构造函数(保证在该类外部,无法通过new的方式来创建对象实例) 3.公有的、静态的、访问该实例对象的方法 
单例模式分为懒汉形和饿汉式 懒汉式

一、懒汉式单例模式:

优点是:类Singleton被加载时并未被分配空间,当调用getInstance()方法时才分配空间,节省内存。
缺点是:并发环境下很可能出现多个Singleton实例。

 1 /**
 2  * 懒汉模式
 3  * 在第一次调用实例方法的时候才会实例化对象
 4  * */
 5 public class Singleton {
 6
 7     private static Singleton instance = null;
 8     private Singleton(){}
 9     public static Singleton getInstance(){
10         if(instance==null){
11             instance = new Singleton();
12         }
13         return instance;
14     }
15
16
17 }

二、饿汉式单例模式:

优点:简单,不存在线程同步问题,避免synchronized造成的资源浪费问题。

缺点:静态类被加载并分配空间,此后instance一直占用资源。

 1 /**
 2  * 饿汉模式 单例类在被编译加载时候,就实例化一个对象交给自己的引用
 3  * */
 4 public class Singleton1 {
 5     private Singleton1() {
 6     }
 7
 8     private static Singleton1 instance = new Singleton1();
 9
10     public static Singleton1 getInstance() {
11         return instance;
12     }
13
14 }

三、懒汉式线程安全单例模式:

 1 public class Singleton {
 2
 3     private static Singleton instance = null;
 4     private Singleton(){}
 5     public static synchronized Singleton getInstance(){
 6         if(instance==null){
 7             instance = new Singleton();
 8         }
 9         return instance;
10     }
11
12
13 }

三、多线程下的懒汉模式:

优点是:使用synchronized关键字避免多线程访问时,出现多个SingletonTest实例。
缺点是:同步方法频繁调用时,效率略低。

 1 /**
 2  * 多线程下的懒汉模式
 3  * 给懒汉式单例模式加锁,避免并发带来的错误,保证线程安全。
 4  * */
 5 public class Singleton2 {
 6     private Singleton2(){}
 7     private static volatile Singleton2 instance = null;
 8     public static synchronized Singleton2 getInstance(){
 9         if(instance==null){
10             synchronized(Singleton2.class){
11                 if(instance==null){
12                     instance = new Singleton2();
13                 }
14             }
15         }
16         return instance;
17     }
18 }

使用场景:

  • 需要频繁实例化然后销毁的对象
  • 创建对象时耗时或者耗费资源过多,但又经常使用的对象
  • 频繁访问数据库或者文件的对象
  • 要求只能存在一个对象

单例模式的优点:

  1. 在内存中只有一个对象,节省内存空间
  2. 避免频繁地创建销毁对象,可以提高性能
  3. 避免对共享资源的多重占用
  4. 可以全局访问
时间: 2024-12-23 10:52:32

单例模式的简单分析的相关文章

FFmpeg源代码简单分析:avformat_alloc_output_context2()

本文简单分析FFmpeg中常用的一个函数:avformat_alloc_output_context2().在基于FFmpeg的视音频编码器程序中,该函数通常是第一个调用的函数(除了组件注册函数av_register_all()).avformat_alloc_output_context2()函数可以初始化一个用于输出的AVFormatContext结构体.它的声明位于libavformat\avformat.h,如下所示. /** * Allocate an AVFormatContext

实时计算,流数据处理系统简介与简单分析

转自:http://www.csdn.net/article/2014-06-12/2820196-Storm 摘要:实时计算一般都是针对海量数据进行的,一般要求为秒级.实时计算主要分为两块:数据的实时入库.数据的实时计算.今天这篇文章详细介绍了实时计算,流数据处理系统简介与简单分析. 编者按:互联网领域的实时计算一般都是针对海量数据进行的,除了像非实时计算的需求(如计算结果准确)以外,实时计算最重要的一个需求是能够实时响应计算结果,一般要求为秒级.实时计算的今天,业界都没有一个准确的定义,什么

java基础---->hashSet的简单分析(一)

对于HashSet而言,它是基于HashMap实现的,底层采用HashMap来保存元素的.今天我们就简单的分析一下它的实现. HashSet的简单分析 一.hashSet的成员变量组成 public class HashSet<E> extends AbstractSet<E> implements Set<E>, Cloneable, java.io.Serializable private transient HashMap<E,Object> map;

FFmpeg的HEVC解码器源代码简单分析:解析器(Parser)部分

上篇文章概述了FFmpeg中HEVC(H.265)解码器的结构:从这篇文章开始,具体研究HEVC解码器的源代码.本文分析HEVC解码器中解析器(Parser)部分的源代码.这部分的代码用于分割HEVC的NALU,并且解析SPS.PPS.SEI等信息.解析HEVC码流(对应AVCodecParser结构体中的函数)和解码HEVC码流(对应AVCodec结构体中的函数)的时候都会调用该部分的代码完成相应的功能. 函数调用关系图 FFmpeg HEVC解析器(Parser)部分在整个HEVC解码器中的

x264源代码简单分析:熵编码(Entropy Encoding)部分

本文记录x264的 x264_slice_write()函数中调用的x264_macroblock_write_cavlc()的源代码.x264_macroblock_write_cavlc()对应着x264中的熵编码模块.熵编码模块主要完成了编码数据输出的功能. 函数调用关系图 熵编码(Entropy Encoding)部分的源代码在整个x264中的位置如下图所示. 单击查看更清晰的图片 熵编码(Entropy Encoding)部分的函数调用关系如下图所示.   单击查看更清晰的图片 从图中

u-boot分析(十一)----MMU简单分析|u-boot分析大结局|学习规划

u-boot分析(十一) 通过前面十篇博文,我们已经完成了对BL1阶段的分析,通过这些分析相信我们对u-boot已经有了一个比较深入的认识,在BL2阶段大部分是对外设的初始化,并且有的我们已经分析过,在这篇博文我打算对BL1阶段没有分析到的重要外设进行简单分析,并结束对u-boot的分析,同时对后面自己的博文进行简单的规划,希望有兴趣的朋友跟我一块学习和研究嵌入式. 今天我们会分析到以下内容: 1.      MMU分析(内容出自我以前的博客) 2.      裸机开发总结 3.      后期

Collections中sort()方法源代码的简单分析

Collections的sort方法代码: public static <T> void sort(List<T> list, Comparator<? super T> c) { Object[] a = list.toArray(); Arrays.sort(a, (Comparator)c); ListIterator i = list.listIterator(); for (int j=0; j<a.length; j++) { i.next(); i.

netback的tasklet调度问题及网卡丢包的简单分析

最近在万兆网卡上测试,出现了之前千兆网卡没有出现的一个现象,tasklet版本的netback下,vm进行发包测试,发现vif的interrupt默认绑定在cpu0上,但是vm发包运行时发现host上面cpu1, cpu2的ksoftirqd很高. 从之前的理解上来说,包从netfront出来通过eventchannel notify触发vif的irq处理函数,然后tasklet_schedule调用tx_action,通过一系列处理流程把包发给网卡.所以vif的interrupt绑在哪个cpu

搜索引擎原理之链接原理的简单分析

在google诞生以前,传统搜索引擎主要依靠页面内容中的关键词匹配搜索词进行排名.这种排名方式的短处现在看来显而易见,那就是很容易被刻意操纵.黑帽SEO在页面上推挤关键词,或加入与主题无关的热门关键词,都能提高排名,使搜索引擎排名结果质量大为下降.现在的搜索引擎都使用链接分析技术减少垃圾,提高用户体验.下面泡馆史明星就来简单的介绍链接在搜索引擎排名中的应用原理. 在排名中计入链接因素,不仅有助于减少垃圾,提高结果相关性,也使传统关键词匹配无法排名的文件能够被处理.比如图片.视频无法进行关键词匹配