博客
关于我
单例模式
阅读量: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/

你可能感兴趣的文章
Mysql学习总结(56)——MySQL用户管理和权限设置
查看>>
Mysql学习总结(57)——MySQL查询当天、本周、本月、上周、本周、上月、距离当前现在6个月数据
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(5)——MySql常用函数大全讲解
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(62)——MySQL连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link问题
查看>>
Mysql学习总结(63)——Mysql数据库架构方案选择与分析
查看>>
Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
查看>>
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(67)——MYSQL慢查询日志
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(71)——数据库介绍(MySQL安装 体系结构、基本管理)再回顾
查看>>
Mysql学习总结(72)——MySQL 开发者开发,设计规范再总结
查看>>