多例:单例设计模式的变形,可以看成是一个缓存池的单例,而缓存池里面可以存多个数据
实例代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
//单例+缓存---没有控制池大小 public class A { //1创建一个单例的池 ( private 即把池封装成单例了) private static Map<String, A> pool = new HashMap<String, A>(); //池--集合: Map:key-value public synchronized static A getInstance(String key){ //2根据key到池中去获取obj A obj = pool.get(key); if (obj== null ){ obj = new A(); pool.put(key, obj); } //3如果该obj存在则返回,否则创建一个新的放入池中并返回 return obj}} |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
import java.util.HashMap; import java.util.Map; //单例+缓存---控制池大小,每个对象的key值由该类内部指定 public class A { //1创建一个单例的池 private static Map<Integer, A> pool = new HashMap<Integer, A>(); //池--集合: Map:key-value //当前对象的序号 private static int num= 0 ; //总数量 private static int MAX_SIZE= 3 ; public synchronized static A getInstance(){ //2根据num到池中去获取obj A obj = pool.get(num); if (obj== null ){ obj = new A(); pool.put(num, obj); } num = (num+ 1 )%MAX_SIZE; //范围: 0 ~ MAX_SIZE-1 //3如果该obj存在则返回,否则创建一个新的放入池中并返回 return obj; } } |
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:http://blog.csdn.net/weixin_37720904/article/details/60476356