Java---设计模块(单例的变形)(多例)
2016-04-02 19:21
471 查看
设计模式1——单例变形(多例)
★ 缓存在单例中的使用
缓存在编程中使用很频繁,有着非常重要的作用,它能够帮助程序实现以空间换取时间,通常被设计成整个应用程序所共享的一个空间,现要求实现一个用缓存存放单例对象的类。
说明:该缓存中可以存放多个该类对象,每个对象以一个key值标识,key值相同时所访问的是同一个单例对象。
给一个key值标识:
测试:
测试输出结果;
可以发现:a1,a3,a5的地址的值是相等的,a2,a4是相等的。
通过Buffer类调用Book类的单例:
Book类:
Buffer类:
测试类;
输出结果:
★ 单例变形——多例模式
把上面缓存的单例实现,做成一个能够控制对象个数的共享空间,供整个应用程序使用。在缓存中维护指定个数的对象,每个对象的key值由该类内部指定,有外部请求时直接返回其中一个对象出去。
说明:相当于维护一个指定数量的对象池,当请求个数超过控制的总数时,开始循环重复使用 。
测试的类:
输出结果:
可以看到: 123行的输出个不相同,
第4行的地址和第一行的相同,
第5行的地址和第二行的相同,
第6行的地址和第三行的相同。
依次类推,循环节点为3.
★ 缓存在单例中的使用
缓存在编程中使用很频繁,有着非常重要的作用,它能够帮助程序实现以空间换取时间,通常被设计成整个应用程序所共享的一个空间,现要求实现一个用缓存存放单例对象的类。
说明:该缓存中可以存放多个该类对象,每个对象以一个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; } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + id; return result; } @Override public 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; } @Override public 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.
相关文章推荐
- Java---设计模块(单例的变形)(多例)
- Spring 源码分析(四) ——MVC(六)M 与 C 的实现
- Spring 源码分析(四) ——MVC(五)初始化阶段
- javamail发送邮件(转)
- Eclipse | Maven : Multiple annotations found at this line
- javah用法
- 20145229吴姗珊 《Java程序设计》第5周学习总结
- java.sql.SQLException: Access denied for user
- MyEclipse主题背景多样化
- Java高级部分之线程重点总结(下)
- Java并发编程系列之八:wait()、notify()和notifyAll()
- Spring学习---1
- Java内存区域划分
- Java---设计模块(设计模块的简介及最简单的俩个单例代码加测试)
- Java---设计模块(设计模块的简介及最简单的俩个单例代码加测试)
- 20160331javaweb之JSP 标签技术
- Java日记——识别简单的验证码
- Eclipse进行可视化的GUI开发3大GUI插件
- 深入理解Java的接口和抽象类
- java集合