Java---设计模块(单例的变形)(多例)
设计模式1——单例变形(多例)
★ 缓存在单例中的使用
缓存在编程中使用很频繁,有着非常重要的作用,它能够帮助程序实现以空间换取时间,通常被设计成整个应用程序所共享的一个空间,现要求实现一个用缓存存放单例对象的类。
说明:该缓存中可以存放多个该类对象,每个对象以一个key值标识,key值相同时所访问的是同一个单例对象。
给一个key值标识:
package cn.hncu.pattern.mulitition;import java.util.HashMap;
import java.util.Map;public class A {private static final Map<String, A> map = new HashMap<String, A>();public A() {}//private也是可以的,这不是关键,关键是map是私有的,这个是集合的单例public static A getInstance(String key){A a = map.get(key);if(a==null){a = new A();map.put(key, a);}return a;}
}
测试:
package cn.hncu.pattern.mulitition;public class Test {public static void main(String[] args) {Atest();}private static void Atest() {A a1 = A.getInstance("hncu1");System.out.println(a1);A a2 = A.getInstance("hncu2");System.out.println(a2);A a3 = A.getInstance("hncu1");System.out.println(a3);A a4 = A.getInstance("hncu2");System.out.println(a4);A a5 = A.getInstance("hncu1");System.out.println(a5);}}
测试输出结果;
cn.hncu.pattern.mulitition.A@11dba45
cn.hncu.pattern.mulitition.A@b03be0
cn.hncu.pattern.mulitition.A@11dba45
cn.hncu.pattern.mulitition.A@b03be0
cn.hncu.pattern.mulitition.A@11dba45
可以发现:a1,a3,a5的地址的值是相等的,a2,a4是相等的。
通过Buffer类调用Book类的单例:
Book类:
package cn.hncu.pattern.mulitition;public class Book {private String name;private int id;private double price;private String details;private static int cont=0;public Book() {id=cont++;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getId() {return id;}public void setId(int id) {this.id = id;}public double getPrice() {return price;}public void setPrice(double price) {this.price = price;}public String getDetails() {return details;}public void setDetails(String details) {this.details = details;}@Overridepublic int hashCode() {final int prime = 31;int result = 1;result = prime * result + id;return result;}@Overridepublic boolean equals(Object obj) {if (this == obj)return true;if (obj == null)return false;if (getClass() != obj.getClass())return false;Book other = (Book) obj;if (id != other.id)return false;return true;}@Overridepublic String toString() {return "Book [id=" + id + "]";}}
Buffer类:
package cn.hncu.pattern.mulitition;import java.util.HashMap;
import java.util.Map;public class Buffer {private static final Map<String, Book> map = new HashMap<String, Book>();public Buffer() {}//private也是可以的,这不是关键,关键是map是私有的,这个是集合的单例public static Book getInstance(String key){Book a = map.get(key);if(a==null){a = new Book();map.put(key, a);}return a;}
}
测试类;
package cn.hncu.pattern.mulitition;public class Test {public static void main(String[] args) {Buffertest();}private static void Buffertest() {Book bk1 = Buffer.getInstance("hncu1");System.out.println(bk1);Book bk2 = Buffer.getInstance("hncu2");System.out.println(bk2);Book bk3 = Buffer.getInstance("hncu3");System.out.println(bk3);Book bk4 = Buffer.getInstance("hncu2");System.out.println(bk4);Book bk5= Buffer.getInstance("hncu1");System.out.println(bk5);}
}
输出结果:
Book [id=0]
Book [id=1]
Book [id=2]
Book [id=1]
Book [id=0]
★ 单例变形——多例模式
把上面缓存的单例实现,做成一个能够控制对象个数的共享空间,供整个应用程序使用。在缓存中维护指定个数的对象,每个对象的key值由该类内部指定,有外部请求时直接返回其中一个对象出去。
说明:相当于维护一个指定数量的对象池,当请求个数超过控制的总数时,开始循环重复使用 。
package cn.hncu.pattern.mulitition.multi;import java.util.HashMap;
import java.util.Map;public class A {private static final Map<Integer, A> map= new HashMap<Integer, A>();private static final int MAX=3;//控制容器中所能使用对象的总个数private static int cont = 1;//代表池中目前将要被使用的对象的序号public static A getInstance(){A a = map.get(cont);if(a==null){a=new A();map.put(cont, a);}cont++;if(cont>MAX){cont=1;}return a;}}
测试的类:
package cn.hncu.pattern.mulitition;public class Test {public static void main(String[] args) {Atest2();}private static void Atest2() {System.out.println(cn.hncu.pattern.mulitition.multi.A.getInstance());System.out.println(cn.hncu.pattern.mulitition.multi.A.getInstance());System.out.println(cn.hncu.pattern.mulitition.multi.A.getInstance());System.out.println(cn.hncu.pattern.mulitition.multi.A.getInstance());System.out.println(cn.hncu.pattern.mulitition.multi.A.getInstance());System.out.println(cn.hncu.pattern.mulitition.multi.A.getInstance());}}
输出结果:
cn.hncu.pattern.mulitition.multi.A@18a49e0
cn.hncu.pattern.mulitition.multi.A@1f82982
cn.hncu.pattern.mulitition.multi.A@16d2633
cn.hncu.pattern.mulitition.multi.A@18a49e0
cn.hncu.pattern.mulitition.multi.A@1f82982
cn.hncu.pattern.mulitition.multi.A@16d2633
可以看到: 123行的输出个不相同,
第4行的地址和第一行的相同,
第5行的地址和第二行的相同,
第6行的地址和第三行的相同。
依次类推,循环节点为3.
转载于:https://www.cnblogs.com/webmen/p/5739332.html
Java---设计模块(单例的变形)(多例)相关推荐
- Spring 为啥默认把 bean 设计成单例的?
点击上方 好好学java ,选择 星标 公众号 重磅资讯.干货,第一时间送达 今日推荐:在滴滴和头条干了 2 年后端开发,太真实-个人原创100W+访问量博客:点击前往,查看更多 熟悉Spring开发 ...
- Java 多线程之单例设计模式
转载:https://segmentfault.com/a/1190000007504892 概念: Java中单例模式是一种常见的设计模式,单例模式的写法有好几种,这里主要介绍两种:懒汉式单例.饿汉 ...
- 笔记:Java中的单例设计模式
之前接触过单例模式,当初不明白这样的设计用意,今天特地研究了下java中的单例设计模式的用处及用法. 单例模式:单例模式是一种常用的软件设计模式.在它的核心结构中只包含一个被称为单例类的特殊类.一个类 ...
- Spring 为啥默认把bean设计成单例的?这篇讲的明明白白的
作者:小小木 juejin.im/post/5cab7ebf518825177637b2f9 熟悉Spring开发的朋友都知道Spring提供了5种scope分别是singleton.prototyp ...
- 【设计模式的开始,设计原则+单例】
前言 每周一更,这周开始和大家一起学习设计模式. 谈谈设计原则 设计原则是很重要的一个东西,大厦之于地基,它是我们编码要牢记在心的一个东西. 单一职责原则 单一职责指的是一个接口只干一件事情嘛?显然这 ...
- JAVA设计模式之单例设计模式
单例模式,是一种常用的软件设计模式.在它的核心结构中只包含一个被称为单例的特殊类.通过单例模式可以保证系统中,应用该模式的类一个类只有一个实例.即一个类只有一个对象实例. 在JAVA中实现单例,必须了 ...
- Spring为啥默认把bean设计成单例的
熟悉Spring开发的朋友都知道Spring提供了5种scope分别是singleton.prototype.request.session.global session.而且默认情况下是single ...
- 26、Java 简单实现单例设计模式(饿汉式和懒汉式)
文章目录 一.概念 二.饿汉式 三.懒汉式 一.概念 ✏️[Singleton Pattern]如果一个类被设计成单例设计模式,则在整个应用程序运行过程中,该类只能存在一个实例. 二.饿汉式 思考:如 ...
- UML基础、建模与设计实战笔记03第3、4章建模工具简介,常见uml建模工具,创建模块,创建类,用例图,参与者,用例,用例描述,用例之间的可视化表示,用例图建模技术及应用,进销存系统用例图
1.常见uml建模工具 建模工具应该具有的功能 绘图 存储 一致性检查 对模型进行组织 导航 写作支持 代码生成 逆向项目 集成 支持多种抽象层和开发过程 文档生成 脚本编程 工具主要有 Rose P ...
最新文章
- 二分查找递归与非递归方式的实现
- Dockerizing a Node.js web app
- 【JUC并发编程04】线程间定制化通信(单标志法存在的问题)
- wireshark合并多个文件_小技巧:快速合并多个excel文件(收藏版)
- 检查CentOS7定时任务是否启用并执行过
- html input不能输入小数_第三课:变量与输入输出的配合使用
- android 项目部署,Android发布项目到JCenter
- Python 数据分析三剑客之 Pandas(三):算术运算与缺失值的处理
- 可执行镜像——开发环境的Docker化之路
- 开源的人品测试机 (windows版)
- 2011对于运维的思考
- 计算机网络安全与防护第三版课后答案,网络安全与防护—笔试题答案
- 每日小记2012.5.1
- kali linux嗅探图片_kali linux 密码嗅探工具 Dsniff 详解
- python中的Numpy包
- NVIDIA Jetson之OTA远程升级Jetpack
- ns注册改服务器,NameSilo域名更改NS服务器简单过程介绍
- 面向对象期末第三阶段
- OpenGL2与ImGui整合入门教程
- nginx系列(十七)nginx下的gzip与vary、预压缩、缓存、反向代理的结合
热门文章
- 【机器视觉】 HDevelop语言基础(六)-错误处理
- 【IT资讯】Linux Kernel 5.8 正式版发布
- 【Tools】Visual Studio 2017下载和安装
- 北师大本科毕业需要过计算机二级吗,全国计算机二级
- 命令点无效怎么处理_怎么更好处理闲置包包,买包卖包都要记住这5点
- matlab由x得到y,matlab 已知x、y值以及函数,求未知参数
- java 怎么判别注释符_java学习笔记二(注释、关键字、标识符)
- android 中的invalidate 和 postInvalidate
- STM32之独立看门狗与窗口看门狗总结
- 量子计算入门-第一部分