多例:单例设计模式的变形,可以看成是一个缓存池的单例,而缓存池里面可以存多个数据
实例代码:
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