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

b2c网站建设方案佛山网站建设制作

b2c网站建设方案,佛山网站建设制作,上海速恒网络科技有限公司,哪里做网站的比较多饿汉式创建 该方式在类加载时就会创建该单实例对象。 静态成员变量 package per.mjn.pattern.singleton.demo1;/*** 饿汉式:静态成员变量*/ public class Singleton {// 1. 私有构造方法private Singleton() {}// 2. 创建静态成员变量private static Singleton i…

饿汉式创建

该方式在类加载时就会创建该单实例对象。

  1. 静态成员变量
package per.mjn.pattern.singleton.demo1;/*** 饿汉式:静态成员变量*/
public class Singleton {// 1. 私有构造方法private Singleton() {}// 2. 创建静态成员变量private static Singleton instance = new Singleton();// 3. 提供一个静态方法,返回静态成员变量public static Singleton getInstance() {return instance;}
}
package per.mjn.pattern.singleton.demo1;public class Client {public static void main(String[] args) {Singleton instance1 = Singleton.getInstance();Singleton instance2 = Singleton.getInstance();System.out.println(instance1 == instance2);}
}

测试输出

true
  1. 静态代码块
package per.mjn.pattern.singleton.demo2;/*** 饿汉式:静态代码块*/
public class Singleton {// 1. 私有构造方法private Singleton() {}// 2. 声明Singleton类型的变量private static Singleton instance;  // null// 3. 在静态代码块中创建Singleton类型的对象static {instance = new Singleton();}// 4. 提供一个静态方法,返回Singleton类型的对象public static Singleton getInstance() {return instance;}
}
package per.mjn.pattern.singleton.demo2;public class Client {public static void main(String[] args) {Singleton s1 = Singleton.getInstance();Singleton s2 = Singleton.getInstance();System.out.println(s1 == s2);}
}

测试输出

true
  1. 枚举方式创建

枚举类实现单例模式借助枚举类型是线程安全的,并且只会装载一次,设计者充分的利用了枚举的这个特性来实现单例模式,枚举的写法非常简单,而且枚举类型是所用单例实现中唯-一种不会被破坏的单例实现模式。

package per.mjn.pattern.singleton.demo6;/*** 枚举实现方式*/
public enum Singleton {INSTANCE;
}
package per.mjn.pattern.singleton.demo6;public class Client {public static void main(String[] args) {Singleton instance = Singleton.INSTANCE;Singleton instance2 = Singleton.INSTANCE;System.out.println(instance == instance2);}
}

测试结果

true

懒汉式创建

类加载不会导致该单实例对象被创建,而是首次使用该对象时才会创建。

package per.mjn.pattern.singleton.demo3;/*** 懒汉式*/
public class Singleton {// 私有构造方法private Singleton() {}// 声明Singleton类型的变量instanceprivate static Singleton instance;// 获取唯一可用的对象public static synchronized Singleton getInstance() {if (instance == null) {instance = new Singleton();}return instance;}
}
package per.mjn.pattern.singleton.demo3;public class Client {public static void main(String[] args) {Singleton instance1 = Singleton.getInstance();Singleton instance2 = Singleton.getInstance();System.out.println(instance1 == instance2);}
}

测试输出

true

双重检查锁方式

package per.mjn.pattern.singleton.demo4;/*** 双重检查锁方式*/
public class Singleton {// 私有构造方法private Singleton() {}// 声明Singleton类型的变量instanceprivate static Singleton instance;// 获取唯一可用的对象public static Singleton getInstance() {// 第一次判断,如果instance的值不为null,不需要抢占锁,直接返回instanceif (instance == null) {synchronized (Singleton.class) {// 第二次判断,如果instance的值不为null,不需要抢占锁,直接返回instanceif (instance == null) {instance = new Singleton();}}}return instance;}
}

双重检查锁模式在多线程的情况下,可能会出现空指针问题,出现问题的原因是JVM在实例化对象的时候会进行优化和指令重排序操作。

要解决双重检查锁模式带来空指针异常的问题,只需要使用volatile关键字,volatile关键字可以保证可见性和有序性

package per.mjn.pattern.singleton.demo4;/*** 双重检查锁方式*/
public class Singleton {// 私有构造方法private Singleton() {}// 声明Singleton类型的变量instanceprivate static volatile Singleton instance;// 获取唯一可用的对象public static Singleton getInstance() {// 第一次判断,如果instance的值不为null,不需要抢占锁,直接返回instanceif (instance == null) {synchronized (Singleton.class) {// 第二次判断,如果instance的值不为null,不需要抢占锁,直接返回instanceif (instance == null) {instance = new Singleton();}}}return instance;}
}

添加volatile关键字之后的双重检査锁模式是一种比较好的单例实现模式,能够保证在多线程的情况下线程安全也不会有性能问题。

静态内部类方式

静态内部类单例模式中实例由内部类创建,由于在加载外部类的过程中,是不会加载静态内部类的,只有内部类的属性/方法被调用时才会被加载,并初始化其静态属性。静态属性由于被 static 修饰,保证只被实例化一次,并且严格保证实例化顺序。

package per.mjn.pattern.singleton.demo5;/*** 静态内部类方式*/
public class Singleton {// 私有构造方法private Singleton() {}// 定义一个静态内部类private static class SingletonHolder {// 在内部类中声明并初始化外部类的对象private static final Singleton INSTANCE = new Singleton();}// 提供公共的访问方式public static Singleton getInstance() {return SingletonHolder.INSTANCE;}
}

第一次加载singleton类时不会去初始化INSTANCE,只有第一次调用getInstance(),虚拟机加载singletonHolder并初始化INSTANCE,这样不仅能确保线程安全,也能保证 singleton 类的唯一性。

静态内部类单例模式是比较常用的一种单例模式。在没有加任何锁的情况下,保证了多线程下的安全,并且没有任何性能影响和空间的浪费。

http://www.dtcms.com/wzjs/472977.html

相关文章:

  • 个人网站建设模板别做网络推广员
  • 找做牙工作上哪个网站廊坊百度快照优化排名
  • 企业建设电子商务网站的预期收益武汉seo网站排名优化公司
  • 怎么做网站教程++用的工具天堂网
  • 多用户商城(c2c)网站制作方案地推推广方案
  • asp网站合法公司网站模板
  • 莱芜公交网站网站免费建站app
  • wordpress 宕机原因灰色seo关键词排名
  • 用记事本做网站缺少body企业网站建设的作用
  • seo短视频网页入口引流网站有哪些全网整合营销
  • 湛江低价网站建设网站优化推广软件
  • 遵义市和城乡建设局网站独立站怎么建站
  • 郑州模板建站系统网站建设
  • 中国设计之窗官方网站2345中国最好的网址站
  • 石家庄个人建站模板外贸网站建设推广公司
  • 织梦动漫网站模板优化方案官网
  • 四川省 政府网站建设上海市人大常委会
  • 如和建立网站太原seo网站优化
  • 邢台本地头条新闻网站关键字优化价格
  • wordpress媒体保存目录seo优化排名易下拉效率
  • 乐从网站建设公司网络推广的优势
  • 专门做毕设的网站seo搜索引擎优化技术教程
  • 小白怎么做淘宝客网站深圳网络推广收费标准
  • wordpress静态链接青岛网站关键词优化公司
  • 怎么建立图片的网站职业培训网络平台
  • 做房地产网站广告销售地推团队接单平台
  • 荆门网站建设电话咨询建网站
  • 做游戏推广网站行业关键词查询
  • 垂直版面网站百度关键字搜索量查询
  • 做移动网站多少钱企业营销网站建设系统