java singleton(单例设计模式)

单例设计模式的主要作用是:

1.控制资源的使用,我们对资源使用线程同步来实现并发访问。

2.节约资源,我们对一个类只进行一个实例化进行全局的资源访问,节约了内存。

3.作为通信媒介,也是数据共享,可以让两个或者多个互不相关的线程或进程之间进行通信。

 

-------------------------------------------------------------------------------------------------------------------

几个使用单例模式设计的应用场景

 

在社交网站上显示在线人数时,我们把在线人数的数据存储到数据库中,我们可以对在线人数这个对象进行new,当上线一个人时就从数据库提取在线人数数据,进行加1的操作,有人下线时,从数据库中提取在线人数数据,进行减1操作。但是这样有线程安全问题,如果在同一个时间有两个或者多个人上线或下线,我们此时进行在线人数数据的增减操作,会出现显示在线人数和我们实际在线人数不一致的问题,所以我们可以使用单例设计模式来很好的解决这个问题。让在线人数示例一个全局对象,所有人都共同使用同一个对象进行数据的访问。

 

我们在使用打印机的时候,如果一个进程或者线程都独立占用打印机,那么打印出来的结果可能是多台打印机执行打印任务的组合,我们可以使用案例设计模式对打印机任务设计一个单例模式的脱机服务Printer Spooler,所有的打印任务都通过Printer Spooler进行。

 

数据库连接池服务也是一个典型的单例设计模式,数据库连接池的作用是节省打开或者关闭数据库时的效率损耗,这种损耗是非常严重的。还可以屏蔽不同数据库之间的差异,降低系统对数据库的耦合度,方便对数据库进行管理等等。数据库连接池是重量级资源,一个应用中只需要一个就可以了,既节省资源又方便操作,非常适合采用单例设计模式。

 

windows操作系统中对任务管理器的操作也是单例设计模式,对管理器中的任务我们只能在同一时间进行单独的操作,我们再进行文件操作时,可能会有多个线程对文件进行操作,采用单例设计模式能完美解决这个问题,所有对文件的操作都通过同一个实例进行,这样就不会产生混乱。

---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

单例模式的特点

1.单例模式只有一个实例,且这个实例是自己创建的,构造方法私有化。

2.为其他类提供获得单例类的静态方法。

------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

单例模式实现方式

1.懒汉式

懒汉式单例模式的特点是获得类的对象时判断是否已经存在对象,若存在直接返回对象,若不存在,在创建对象并返回对象。其特点时加载时间快,但是运行时比较慢。

懒汉式实现代码:

public class Singleton {
    
   private static Singleton instance=null;
   
   public synchronized static Singleton getInstance() {
       if(instance==null) {
           instance=new Singleton();
       }
       return instance;
    }
   
   private Singleton() {
       System.out.println("这是单例设计模式懒汉式");
   }
}

懒汉式只有外部对象第一次请求实例才去创建。

 

饿汉式:饿汉式单例模式在类加载时就开始创建对象,其特点是加载时间长,但是运行速度快。

饿汉式代码:

public class HungerySingleton {
    private static final HungerySingleton instance=new HungerySingleton();
    
    private HungerySingleton() {
        System.out.println("这是饿汉式单例模式");
    }
    
    public static HungerySingleton getInstance() {
        return instance;
    }
}

------------------------------------------------------------------------------------------------------------------------------------------------------------

我们注意到懒汉式单例模式使用了synchronized关键字,目的是为了在同一时间只能有一个线程对该方法进行访问,避免多个线程访问该方法产生多个实例。

而饿汉式在类加载时就完成了初始化,所以对外部的获取实例的接口方法没有使用synchronized关键字修饰。

 

----------------------------------------------------------------------------------------------------------------------------------------------------------------

枚举类型单例设计模式

实现简单,线程安全,任何情况下都是一个单例,无偿提供序列化机制,绝对防止多次实例化,即使面对复杂的序列化或者反射攻击时。

 

实现代码:

public enum SingletonEnum {
    
    himself;
    private Connection con=null;
    private SingletonEnum(){
con=new Connection();
}

public Connection getConnection(){
return con;
}
}

调用方法:SingletonEnum.himself.doingSomething();

 

   

 

转载于:https://www.cnblogs.com/zzuli/p/9304835.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值