当前位置: 首页 > news >正文

贵阳网站建设端觉武汉seo广告推广

贵阳网站建设端觉,武汉seo广告推广,梦想小镇旅游官方网站建设,好学校平台网站模板单例模式简介 单例模式(Singleton Pattern)是 Java 中最简单的设计模式之一。这种类型的设计模式属于创建型模式,创建型模式是一类最常用的设计模式,在软件开发中应用非常广泛,它提供了一种创建对象的最佳方式。 单例模…

单例模式简介

  单例模式(Singleton Pattern)是 Java 中最简单的设计模式之一。这种类型的设计模式属于创建型模式,创建型模式是一类最常用的设计模式,在软件开发中应用非常广泛,它提供了一种创建对象的最佳方式。
单例模式是指在内存中只会创建且仅创建一次对象的设计模式。在程序中多次使用同一个对象且作用相同时,为了防止频繁地创建对象使得内存飙升,单例模式可以让程序仅在内存中创建一个对象,让所有需要调用的地方都共享这一单例对象。这个类提供了一种访问其唯一的对象的方式,可以直接访问,不需要实例化该类的对象。

  单例模式的特点
 1、单例类只能有一个实例。
 2、单例类必须自己创建自己的唯一实例。
 3、单例类必须给所有其他对象提供这一实例。

  单例模式有两种类型

  • 懒汉式:在真正需要使用对象时才去创建该单例类对象。顾名思义就是实例在用到的时候才去创建,“比较懒”,用的时候才去检查有没有实例,如果有则返
  • 饿汉式:在类加载时已经创建好该单例对象,等待被程序使用。顾名思义就是实例在用到的时候才去创建,“比较懒”,用的时候才去检查有没有实例,如果有则返。顾名思义,就是“比较勤”,实例在初始化的时候就已经建好了,不管你有没有用到,都先建好了再说。好处是没有线程安全的问题,坏处是浪费内存空间。

  实现单例模式的八种方式:

  1. 饿汉式(静态常量)
    优点:在类装载的时候就完成实例化。避免了线程同步问题。
    缺点:在类装载的时候就完成实例化。实现了单例,无法做到延迟加载,消耗内存。。
public class Eager{private final static Eager instance= new Eager();private Eager() { }public static Eager getInstance( {return instance;}
}    
  1. 饿汉式(静态代码块)
    这种方式和上面的方式其实类似,只不过将类实例化的过程放在了静态代码块中,也是在类装载的时候,就执行静态代码块中的代码,初始化类的实例。
    优点:在类装载的时候就完成实例化。避免了线程同步问题。
    缺点:在类装载的时候就完成实例化。如果从始至终从未使用过这个实例,则会造成内存的浪费。
public class Eager{private static Eager instance;static {instance = new Eager() ;
}
private Eager() { }public static Eager getInstance( {return instance;}
}
  1. 懒汉式(线程不安全)
    这种写法只能在单线程下使用。如果在多线程下,一个线程进入了if (eager == null)判断语句块,还未来得及往下执行,另一个线程也通过了这个判断语句,这时便会产生多个实例。所以在多线程环境下不可使用这种方式。
public class Lazy{private static Lazy lazy;private Lazy() { }public static Lazy getInstance(){if (lazy == null) {lazy = new Lazy() ;}return lazy;}
}
  1. 懒汉式(线程安全,同步方法)
    缺点:效率太低了,每个线程在想获得类的实例时候,执行getInstance()方法都要进行同步。
public class Lazy{private static Lazy lazy;private Lazy() { }public static synchronized Lazy getInstance() {if(lazy == null) {lazy = new Lazy() ;}return lazy;}
}
  1. 懒汉式(线程安全,同步代码块)
    这种同步并不能起到线程同步的作用。跟第3种实现方式遇到的情形一致,假如一个线程进入了if (eager == null)判断语句块,还未来得及往下执行,另一个线程也通过了这个判断语句,这时便会产生多个实例。
public class Lazy{private static Lazy lazy;private Lazy() { }public static Lazy getInstance() {if (lazy == null) {synchronized (Lazy.class) {lazy = new Lazy() ;}}return lazy;}
}
  1. 双重检查【推荐使用】
    Double-Check概念对于多线程开发者来说不会陌生,如代码中所示,我们进行了两次if (singleton == null)检查,这样就可以保证线程安全了。这样,实例化代码只用执行一次,后面再次访问时,判断if (singleton == null),直接return实例化对象。
    优点:线程安全;延迟加载;效率较高。
public class DoubleCheck{private static volatile DoubleCheck doublecheck ;private DoubleCheck() {}public static DoubleCheck getInstance() {if (doublecheck == null) {synchronized (DoubleCheck .class) {if (doublecheck == null) {doublecheck = new DoubleCheck () ;}}}return doublecheck;}
}

  总结

  1. 单例模式有两种:懒汉式、饿汉式
  2. 懒汉式:在需要用到对象时才实例化对象,解决了并发安全和性能低下问题
  3. 饿汉式:在类加载时已经创建好该单例对象,在获取单例对象时直接返回对象即可,不会存在并发安全和性能问题。
  4. 在开发中如果对内存要求非常高,那么使用懒汉式写法,可以在特定时候才创建该对象;
  5. 如果对内存要求不高使用饿汉式写法,因为简单不易出错,且没有任何并发安全和性能问题
  6. 为了防止多线程环境下,因为指令重排序导致变量报NPE,需要在单例对象上添加volatile关键字防止指令重排序
http://www.hkea.cn/news/673578/

相关文章:

  • 用二级页面做网站的源代码自助建站系统破解版
  • 网站上怎么做动画广告推广策略包括哪些内容
  • 广州网站优化公司大亚湾发布
  • 广州网站开发招聘百度经验悬赏令
  • 吴江建设局网站郑州粒米seo外包
  • 建设工程合同纠纷与劳务合同纠纷seo培训教程视频
  • 找网站建设公司哪家最好沈阳市网站
  • sh域名做的好的网站什么是营销
  • 网站平台怎么做推广一站式网络推广服务
  • 百度对新网站排名问题兰州seo快速优化报价
  • 网站建设常用代码湘潭网络推广
  • 做网站上传图片一直错误好用搜索引擎排名
  • 钟祥网站建设网络推广的含义
  • 新闻类网站源码青岛官网seo
  • 网站优化哪里可以做百度营销客户端
  • 常德建设局网站北京优化网站方法
  • 用ip做网站优化手机流畅度的软件
  • 为网站添加统计媒介
  • 商业设计网站推荐互联网营销师证书是国家认可的吗
  • 做网站的是干嘛的怎样把自己的产品放到网上销售
  • 品牌型网站制作价格2022年小学生新闻摘抄十条
  • 政府网站群集约化建设网络暴力事件
  • 可以做卷子的网站游戏app拉新平台
  • 长沙优化网站关键词社区营销
  • 个人网站制作价格表重庆关键词优化
  • 网站开发ideseo优化网站模板
  • 关于制作网站收费标准怎样把个人介绍放到百度
  • 网站建设 绵阳百度开放平台
  • discuz修改网站标题微信小程序开发平台
  • 怎么做国内网站吗seo顾问培训