Android 单例模式比较和优化
来源:互联网 发布:博弈树算法包括哪些 编辑:程序博客网 时间:2024/06/05 14:49
Android 单例模式比较和优化
单例模式
一、定义
单例模式保证了程序中只有一个实例但是可以在全局中访问到。
二、优势
1、由于只有一个实例,故可以减少内存开销
2、可以避免对资源的多重占用,避免对同一资源进行多种操作
3、设置了全局的资源访问,可以优化和共享全局资源访问
三、常用方式
(1)懒汉式
public class Singleton {
private static Singleton instance = null;
private Singleton() {
}
public static Singleton getInstance() {
if (instance == null) {
instance = new Singleton();
}
return instance;
}
}
优点:在需要的时候才去加载
缺点:在多线程的环境下,会出现线性不安全的情况
(2) 加锁方式
public static synchronized Singleton getInstance() {
if (instance == null) {
instance = new Singleton();
}
return instance;
}
优点:解决了线性同步问题
缺点:每次调用都要判断同步锁,导致效率低
(3) 加双重锁
publci static synchronized Singleton getInstance(){
if(instance == null){
synchronized(Object){
if(instance == null){
instance = new Singleton();
}
}
}
}
在JVM编译的过程中会出现指令重排的优化过程,这就会导致当 instance实际上还没初始化,就可能被分配了内存空间,也就是说会出现 instance !=null 但是又没初始化的情况,这样就会导致返回的 instance报错。在JDK1.5之后,官方已经注意到这种问题,因此调整了JMM、具体化了volatile关键字,因此如果JDK是1.5或之后的版本,只需要将instance的定义改成“private volatile static SingletonKerriganD instance = null;”就可以保证每次都去instance都从主内存读取,就可以使用DCL的写法来完成单例模式。当然volatile或多或少也会影响到性能。
优点:在并发量不高、安全性不高的情况下可以很好的运行
缺点:在不同的编译环境下可能出现不同的问题
(4)内部类
public class SingletonInner {
/**
* 私有的构造器
*/
private SingletonInner() {
}
/**
* 内部类实现单例模式
* 延迟加载,减少内存开销
*
*/
private static class SingletonHolder {
private static SingletonInner instance = new SingletonInner();
}
public static SingletonInner getInstance() {
return SingletonHolder.instance;
}
protected void method() {
System.out.println("ibinbin");
}
}
优点:延迟加载、线性安全、减少内存消耗
结语:在Android中存在一些单例模式的类,比如InputMethodManager类,CalendarDatabaseHelper类、Editable类,比如数据库的设计和优化,账号信息管理系统的开发
单例模式
一、定义
单例模式保证了程序中只有一个实例但是可以在全局中访问到。
二、优势
1、由于只有一个实例,故可以减少内存开销
2、可以避免对资源的多重占用,避免对同一资源进行多种操作
3、设置了全局的资源访问,可以优化和共享全局资源访问
三、常用方式
(1)懒汉式
public class Singleton {
private static Singleton instance = null;
private Singleton() {
}
public static Singleton getInstance() {
if (instance == null) {
instance = new Singleton();
}
return instance;
}
}
优点:在需要的时候才去加载
缺点:在多线程的环境下,会出现线性不安全的情况
(2) 加锁方式
public static synchronized Singleton getInstance() {
if (instance == null) {
instance = new Singleton();
}
return instance;
}
优点:解决了线性同步问题
缺点:每次调用都要判断同步锁,导致效率低
(3) 加双重锁
publci static synchronized Singleton getInstance(){
if(instance == null){
synchronized(Object){
if(instance == null){
instance = new Singleton();
}
}
}
}
在JVM编译的过程中会出现指令重排的优化过程,这就会导致当 instance实际上还没初始化,就可能被分配了内存空间,也就是说会出现 instance !=null 但是又没初始化的情况,这样就会导致返回的 instance报错。在JDK1.5之后,官方已经注意到这种问题,因此调整了JMM、具体化了volatile关键字,因此如果JDK是1.5或之后的版本,只需要将instance的定义改成“private volatile static SingletonKerriganD instance = null;”就可以保证每次都去instance都从主内存读取,就可以使用DCL的写法来完成单例模式。当然volatile或多或少也会影响到性能。
优点:在并发量不高、安全性不高的情况下可以很好的运行
缺点:在不同的编译环境下可能出现不同的问题
(4)内部类
public class SingletonInner {
/**
* 私有的构造器
*/
private SingletonInner() {
}
/**
* 内部类实现单例模式
* 延迟加载,减少内存开销
*
*/
private static class SingletonHolder {
private static SingletonInner instance = new SingletonInner();
}
public static SingletonInner getInstance() {
return SingletonHolder.instance;
}
protected void method() {
System.out.println("ibinbin");
}
}
优点:延迟加载、线性安全、减少内存消耗
结语:在Android中存在一些单例模式的类,比如InputMethodManager类,CalendarDatabaseHelper类、Editable类,比如数据库的设计和优化,账号信息管理系统的开发
阅读全文
1 0
- Android 单例模式比较和优化
- Android 单例模式比较和优化
- 单例模式和静态方法比较
- 优化单例模式
- 单例模式优化
- 单例模式优化
- 单例模式优化
- Android单例模式怎么写比较好?
- 单例模式和静态方法的比较
- android开发_性能优化_单例模式
- Android源码和单例模式
- 单例模式优化探索
- 单例模式--锁优化
- 【设计模式】单例模式优化
- android源码里的单例模式和模版模式
- android 单例模式和策略模式的结合使用
- android 单例模式!
- android 单例模式
- faster rcnn在Ubuntu系统下cpu模式的算法实现
- C++记录程序运行的时间
- 202. Happy Number
- 利用VS2013编译C语言程序
- HDU-1527-取石子游戏【威佐夫博弈】
- Android 单例模式比较和优化
- POJ 1986 Distance Queries(求最近公共祖先,LCA-Tarjan)
- windows下搭建python+selenium环境(批量删除sina微博)
- win10无法安装迅雷精简版解决办法
- 成为优秀程序员的黄金10条法则
- POJ 1065 Wooden Sticks(贪心 LIS思想)
- 【分治 求最近点对】hdu 1007 Quoit Design
- jq判断一个元素是否在可视范围内
- 【UR #4】元旦激光炮