java单例模式的几种写法,关于java:单例模式的几种写法

1、动态初始化

/**

饿汉式

类加载到内存后,就实例化一个单例,jvm保障线程平安

简略实用,举荐应用

惟一毛病:不论用到与否,类加载时就实现实例化

(话说你不必的,你转载它干啥)

个别这种就够用了

*/

public class Mgr01 {

【腾讯云】云产品限时秒杀,爆款1核2G云服务器,首年99元

private static final Mgr01 INSTANCE = new Mgr01();

private Mgr01(){}

public static Mgr01 getInstance(){return INSTANCE; }

public void m(){

System.out.println("m");

}

public static void main(String[] args){

Mgr01 m1 = Mgr01.getInstance();

Mgr01 m2 = Mgr01.getInstance();

System.out.println(m1 == m2);

}

}

//这种写法跟Mgr01一个意思

public class Mgr02 {

private static final Mgr02 INSTANCE;

static {

INSTANCE = new Mgr02();

}

private Mgr02(){}

public static Mgr02 getInstance(){return INSTANCE;}

public void m(){

System.out.println("m");

}

public static void main(String[] args) {

Mgr02 m1 = Mgr02.getInstance();

Mgr02 m2 = Mgr02.getInstance();

System.out.println(m1 == m2);

}

}

2、加锁+双重查看~~~~

/**

lazy loading

也称懒汉式

尽管达到了按需初始化的目标,然而带来线程不平安问题

能够通过synchronize解决,这个是能够失常应用的,但也带来效率降落问题

*/

public class Mgr04 {

private static volatile Mgr04 INSTANCE;

private Mgr04() {

}

//这个synchronized锁定的是Mgr04.class,因为锁是加在static下面的

public static synchronized Mgr04 getInstance(){

if(INSTANCE == null){

try {

Thread.sleep(1);

}catch (InterruptedException e){

e.printStackTrace();

}

INSTANCE = new Mgr04();

}

return INSTANCE;

}

public void m(){

System.out.println("m");

}

public static void main(String[] args) {

for(int i = 0; i < 100; i++) {

new Thread(()->{

System.out.println(Mgr04.getInstance().hashCode());

}).start();

}

}

}

/**

lazy loading

也称懒汉式

尽管达到了按需初始化的目标,然而带来线程不平安问题

能够通过synchronize解决,这个是能够失常应用的,但也带来效率降落

这是一种完满写法

*

*/

public class Mgr06 {

private static volatile Mgr06 INSTANCE;

private Mgr06() {

}

public static Mgr06 getInstance(){

if(INSTANCE == null){

//双重查看

synchronized(Mgr06.class){

if(INSTANCE == null){

try {

Thread.sleep(1);

}catch (InterruptedException e){

e.printStackTrace();

}

INSTANCE = new Mgr06();

}

}

}

return INSTANCE;

}

public void m(){

System.out.println("m");

}

public static void main(String[] args) {

for(int i = 0; i < 100; i++) {

new Thread(()->{

System.out.println(Mgr06.getInstance().hashCode());

}).start();

}

}

}

3、动态外部类形式

/**

动态外部类形式

JVM保障单例

胜在动态的货色只加载一次,并且加载外部类时不会加载外部类,这样能够实现懒加载

比Mgr01完满,

*/

public class Mgr07 {

private Mgr07(){}

private static class Mgr07Holder{

private final static Mgr07 INSTANCE = new Mgr07();

}

public static Mgr07 getInstance(){

return Mgr07Holder.INSTANCE;

}

public void m(){

System.out.println("m");

}

public static void main(String[] args) {

for(int i = 0; i< 100; i++){

new Thread(()->{

System.out.println(Mgr07

.getInstance().hashCode());

}).start();

}

}

}

4、枚举模式

/**

不仅能够解决线程同步,还能够避免反序列化

*/

public enum Mgr08 {

INSTANCE;

public void m(){}~~~~

public static void main(String[] args) {

for(int i = 0; i< 100; i++){

new Thread(()->{

System.out.println(Mgr08.INSTANCE.hashCode());

}).start();

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值