博客
关于我
单例模式
阅读量:638 次
发布时间:2019-03-14

本文共 1281 字,大约阅读时间需要 4 分钟。

什么是单例模式

希望一个类,在程序运行期间,只有一个实例,任何外界代码,都不能随意创建实例

要实现单例模式,有要点如下

  1. 如果不想外界随意创建实例,那么类的构造方法必须是private修饰,必须私有
  2. 外界代码要想获取类的实例,必须通过调用类的静态方法,获取类的实例
  3. 那么类必须提供一个静态方法,getInstance(),来提供获取唯一实例的功能 getInstance(),保证类的实例创建,有且仅有一次创建!

单例模式使用场景

1、配置管理组件,可以在读取大量配置信息后,用力模式方式,将配置信息仅仅保存在一个实例变量中,避免对于静态不变的配置信息,反复多次读取

2、JDBC辅助件,全局只有一个实例,实例中持有一个内部简单数据源
也就是创建数据库连接池

单例模式简单实现

package cn.tkk.test;public class Singleton {    // 首先必须有一个私有的静态变量,来引用自己即将被创建出来的单例    private static Singleton instace=null;    /**     * 构造方法私有化,保证外界代码不能随意创建类的实例     */    private Singleton(){    }    /**     * 负责创建唯一实例,并且返回这个唯一实例     *     * 多线程并发?     *     * 为什么锁不加在方法上?     * 这样做能保证第一次创建实例时不会重复创建     * 但是以后多线程并发访问这个方法呢?方法是同步的 那么就会一直等待 性能降低  不可取     *     *     *     * @return     */    public  static Singleton getInstance(){        //两步检查机制        //首先第一步,多个线程过来的时候,判断instance是否为null        //如果为null那么进入if判断        if(instace==null){            //这里,进行多线程同步            //同意时间只有一个线程获取到Singleton Class对象的锁            //其他线程,原地等待,等着获取锁            synchronized (Singleton.class){                if(instace==null){                //只有第一个获取到锁的线程  会执行if后的代码 发现instance是null 然后去创建这个单例                //以后线程再次进入 会返现 oh 对象已经存在 无需重复创建                    instace=new Singleton();                }            }        }        return instace;    }}

转载地址:http://kqblz.baihongyu.com/

你可能感兴趣的文章
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>