设计模式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---设计模块(单例的变形)(多例)相关推荐

  1. Spring 为啥默认把 bean 设计成单例的?

    点击上方 好好学java ,选择 星标 公众号 重磅资讯.干货,第一时间送达 今日推荐:在滴滴和头条干了 2 年后端开发,太真实-个人原创100W+访问量博客:点击前往,查看更多 熟悉Spring开发 ...

  2. Java 多线程之单例设计模式

    转载:https://segmentfault.com/a/1190000007504892 概念: Java中单例模式是一种常见的设计模式,单例模式的写法有好几种,这里主要介绍两种:懒汉式单例.饿汉 ...

  3. 笔记:Java中的单例设计模式

    之前接触过单例模式,当初不明白这样的设计用意,今天特地研究了下java中的单例设计模式的用处及用法. 单例模式:单例模式是一种常用的软件设计模式.在它的核心结构中只包含一个被称为单例类的特殊类.一个类 ...

  4. Spring 为啥默认把bean设计成单例的?这篇讲的明明白白的

    作者:小小木 juejin.im/post/5cab7ebf518825177637b2f9 熟悉Spring开发的朋友都知道Spring提供了5种scope分别是singleton.prototyp ...

  5. 【设计模式的开始,设计原则+单例】

    前言 每周一更,这周开始和大家一起学习设计模式. 谈谈设计原则 设计原则是很重要的一个东西,大厦之于地基,它是我们编码要牢记在心的一个东西. 单一职责原则 单一职责指的是一个接口只干一件事情嘛?显然这 ...

  6. JAVA设计模式之单例设计模式

    单例模式,是一种常用的软件设计模式.在它的核心结构中只包含一个被称为单例的特殊类.通过单例模式可以保证系统中,应用该模式的类一个类只有一个实例.即一个类只有一个对象实例. 在JAVA中实现单例,必须了 ...

  7. Spring为啥默认把bean设计成单例的

    熟悉Spring开发的朋友都知道Spring提供了5种scope分别是singleton.prototype.request.session.global session.而且默认情况下是single ...

  8. 26、Java 简单实现单例设计模式(饿汉式和懒汉式)

    文章目录 一.概念 二.饿汉式 三.懒汉式 一.概念 ✏️[Singleton Pattern]如果一个类被设计成单例设计模式,则在整个应用程序运行过程中,该类只能存在一个实例. 二.饿汉式 思考:如 ...

  9. UML基础、建模与设计实战笔记03第3、4章建模工具简介,常见uml建模工具,创建模块,创建类,用例图,参与者,用例,用例描述,用例之间的可视化表示,用例图建模技术及应用,进销存系统用例图

    1.常见uml建模工具 建模工具应该具有的功能 绘图 存储 一致性检查 对模型进行组织 导航 写作支持 代码生成 逆向项目 集成 支持多种抽象层和开发过程 文档生成 脚本编程 工具主要有 Rose P ...

最新文章

  1. 二分查找递归与非递归方式的实现
  2. Dockerizing a Node.js web app
  3. 【JUC并发编程04】线程间定制化通信(单标志法存在的问题)
  4. wireshark合并多个文件_小技巧:快速合并多个excel文件(收藏版)
  5. 检查CentOS7定时任务是否启用并执行过
  6. html input不能输入小数_第三课:变量与输入输出的配合使用
  7. android 项目部署,Android发布项目到JCenter
  8. Python 数据分析三剑客之 Pandas(三):算术运算与缺失值的处理
  9. 可执行镜像——开发环境的Docker化之路
  10. 开源的人品测试机 (windows版)
  11. 2011对于运维的思考
  12. 计算机网络安全与防护第三版课后答案,网络安全与防护—笔试题答案
  13. 每日小记2012.5.1
  14. kali linux嗅探图片_kali linux 密码嗅探工具 Dsniff 详解
  15. python中的Numpy包
  16. NVIDIA Jetson之OTA远程升级Jetpack
  17. ns注册改服务器,NameSilo域名更改NS服务器简单过程介绍
  18. 面向对象期末第三阶段
  19. OpenGL2与ImGui整合入门教程
  20. nginx系列(十七)nginx下的gzip与vary、预压缩、缓存、反向代理的结合

热门文章

  1. 【机器视觉】 HDevelop语言基础(六)-错误处理
  2. 【IT资讯】Linux Kernel 5.8 正式版发布
  3. 【Tools】Visual Studio 2017下载和安装
  4. 北师大本科毕业需要过计算机二级吗,全国计算机二级
  5. 命令点无效怎么处理_怎么更好处理闲置包包,买包卖包都要记住这5点
  6. matlab由x得到y,matlab 已知x、y值以及函数,求未知参数
  7. java 怎么判别注释符_java学习笔记二(注释、关键字、标识符)
  8. android 中的invalidate 和 postInvalidate
  9. STM32之独立看门狗与窗口看门狗总结
  10. 量子计算入门-第一部分