惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

SecWiki News
SecWiki News
I
InfoQ
The Cloudflare Blog
人人都是产品经理
人人都是产品经理
博客园 - Franky
T
Tailwind CSS Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
量子位
博客园_首页
罗磊的独立博客
V
V2EX
李成银的技术随笔
大猫的无限游戏
大猫的无限游戏
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
True Tiger Recordings
Vercel News
Vercel News
Cyberwarzone
Cyberwarzone
Cisco Talos Blog
Cisco Talos Blog
F
Fox-IT International blog
D
Darknet – Hacking Tools, Hacker News & Cyber Security
M
Microsoft Research Blog - Microsoft Research
Know Your Adversary
Know Your Adversary
爱范儿
爱范儿
The Register - Security
The Register - Security
G
Google Developers Blog
The Hacker News
The Hacker News
Malwarebytes
Malwarebytes
S
Securelist
博客园 - 三生石上(FineUI控件)
Jina AI
Jina AI
T
Threat Research - Cisco Blogs
T
The Exploit Database - CXSecurity.com
S
SegmentFault 最新的问题
博客园 - 叶小钗
F
Fortinet All Blogs
Apple Machine Learning Research
Apple Machine Learning Research
宝玉的分享
宝玉的分享
博客园 - 聂微东
T
Threatpost
博客园 - 【当耐特】
D
Docker
P
Privacy & Cybersecurity Law Blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
G
GRAHAM CLULEY
V
Visual Studio Blog
C
Cisco Blogs
IT之家
IT之家
S
Security Archives - TechRepublic
Latest news
Latest news
阮一峰的网络日志
阮一峰的网络日志

浮华生

Elasticsearch 检索性能优化 舆情监控系统综述 2024 半年度总结 2023 年终总结 - 浮华生 异地机器组网方案 Kubernetes 部署 Elasticsearch 和 Kibana 2022 年终总结 RabbitMQ connection channel 的关系 Kafka Java 客户端 Producer 原理分析 RabbitMQ 和 Kafka 应用原理简单对比 阿里云 OpenSearch 介绍 Golang Array 和 Slice 区别 - 浮华生 Mac OS 下打造 golang nvim 编程环境之基础配置 电商搜索技术总结 电商搜索业务总结 2021 年终总结 Cypress 实践总结 年终总结 关于我 使用 cucumber 进行行为驱动开发(BDD) 微服务应用集成 SpringCloud 步骤 电商搜索数据同步方案 - 浮华生 通过一道数值转换题重温计算机补码 macOS 系统推荐的一些软件 DevOps 实施规划(持续更新) rabbitmq 如何提高可靠性并保证消费端幂等 AMQ Model总结 结对编程 RSocket 介绍 面向对象的理解 企业平台技术框架 对创业的思考 - 浮华生 知难行易 - 浮华生 一年工作经验总结 - 浮华生 我与领域驱动之缘 TDD 中使用的工具 tf-idf 算法 gitlab 添加代码规范检测 query 改写 阶段性总结 操作系统作用 无标题 hamming-distance ElasticSearch API 基本操作 elasticsearch 集群容错 ElasticSearch 基础概念 技术选型怎么做 条件概率、全概率与贝叶斯公式 年终总结 迁移到 ubuntu18 的问题及配置 总结 使用 psi-probe 监控 Tomcat Tomcat 远程 Debug jstack 死循环和死锁定位 jmap & mat 内存溢出 JVM 常用参数查看 - 浮华生 周总结(8.13-8.19) - 浮华生 周总结(7.30-8.4) 使用移位运算符 master 公式 - 浮华生 VMware 12 NAT网络下配置 ubuntu 16.04 LTS 系统静态 IP - 浮华生 关于进制的计算 项目总结 第三篇 项目总结 第二篇 editor.md 富文本编辑器的使用 项目总结 第一篇 - 浮华生 2017至今总结 谈谈微服务 tor 使用 归档 搜索 - 浮华生 搜索 && 推荐
单例模式 - 浮华生
2017-10-09 · via 浮华生

单例模式Singleton 作用:保证整个应用程序中某个实例有且只有一个 类型:饿汉模式和懒汉模式

首先创建一个Pattern类,什么都不写。

1
2
3
4
5
package top.richmanroad.demo;

public class Pattern {

}

再新建一个测试Test类

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
package top.richmanroad.demo;

public class Test {
public static void main(String[] args) {
    
    Pattern pt1=new Pattern();
    Pattern pt2=new Pattern();
    Pattern pt3=new Pattern();
    System.out.println(pt1);
    System.out.println(pt2);
    System.out.println(pt3);
}
}

控制台输出结果

1
2
3
top.richmanroad.demo.Pattern@15db9742
top.richmanroad.demo.Pattern@6d06d69c
top.richmanroad.demo.Pattern@7852e922

可以看出其三次输出的地址不相同,说明此时创建了三个不同的实例

饿汉模式

将构造方法私有化,不能被外部直接创建对象,此时在Test类中就不能直接实例化对象了,然后在Pattern类中创建唯一的实例,并且将其变为类的成员(static将方法变为类所有),这样在Test类中可以直接使用;类名.成员名来获取对象。此时Pattern类如下:

1
2
3
4
5
6
7
8
package top.richmanroad.demo;

public class Pattern {
//将构造方法私有化,不能被外部直接创建对象
    private Pattern(){}
//创建类的唯一实例
    static Pattern instance=new Pattern();
}

Test类:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
package top.richmanroad.demo;

public class Test {
public static void main(String[] args) {
    
    Pattern pt1=Pattern.instance;
    Pattern pt2=Pattern.instance;
    Pattern pt3=Pattern.instance;
    System.out.println(pt1);
    System.out.println(pt2);
    System.out.println(pt3);
}
}

控制台输出结果:

1
2
3
top.richmanroad.demo.Pattern@15db9742
top.richmanroad.demo.Pattern@15db9742
top.richmanroad.demo.Pattern@15db9742

可以看出三者的地址指向一处,说明此时只创建了一个实例。

接下来为了安全,需要将对Pattern类进行封装(面向对象思想),此时我们的Pattern类就变成了如下内容

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
package top.richmanroad.demo;

public class Pattern {
//将构造方法私有化,不能被外部直接创建对象
    private Pattern(){}
//创建类的唯一实例
 private static Pattern instance=new Pattern();
//提供一个用于获取实例的方法
 public static Pattern getInstance(){
     return instance;
 }
    
}

Test类修改内容并输出,结果同上

1
Pattern pt1=Pattern.getInstance();

上面这种方法为饿汉模式,意思大致为:static为静态修饰符,当Pattern类加载时它就会创建一个唯一的实例,不管后面有没有调用,都随类一起产生。

懒汉模式

LazyPattern类

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
package top.richmanroad.demo;

public class LazyPattern {
    //构造方法私有化
private LazyPattern(){
}
//声明类的唯一实例,使用private修饰
private static LazyPattern instance;
//提供一个用于获取实例的方法,使用public static修饰
public static LazyPattern getInstance() {
    if(instance==null){
        instance=new LazyPattern();
    }
    return instance;
}

}

类中只是声明了一个唯一的实例,并没有创建,只有当用户获取实例时才去判断这个实例是否为空

饿汉模式懒汉模式
区别加载时速度慢,运行时获取对象比较快加载速度快,运行时获取对象速度比较慢
线程安全不安全