public class CacheFinal{
private final String name;
private static CacheFinal[] cache = new CacheFinal[10];
//记录缓存实例在缓存的位置,cache[p-1]是最新的缓存实例
private static int p =0;
public CacheFinal(String name){//是否隐藏构造器取决于系统需要
this.name = name;
}
public String getName(){
return name;
}
public static CacheFinal valueOf(String name){
//遍历已经缓存的对象
for(int i =0; i<p;i++){
//如果已有相同实例,直接返回该缓存的实例
if(cache[i] != null && cache[i].getName().equals(name)){
return cache[i];
}
}
//如果缓存已经满了
if(p==10){
//覆盖第一个对象
cache[0] = new CacheFinal(name);
//把p设为1
p=1;
return cache[0];
}else{
//把新创建的对象缓存起来,p加1
cache[p++] = new CacheFinal(name);
return cache[p-1];
}
}
//equals方法
public boolean equals(Object obj){
if(obj instanceof CacheFinal){
CacheFinal cf = (CacheFinal) obj;
if(name.equals(cf.getName())){
return true;
}
}
return false;
}
//hashcode方法
public int hashCode(){
return name.hashCode();
}
public static void main(String[] args){
CacheFinal c1 = CacheFinal.valueOf("hello");
CacheFinal c2 = CacheFinal.valueOf("hello");
//比较是否是引用了同一个对象
System.out.println(c1 == c2);
}
}
java.lang.Integer类,就采用了这种缓存处理策略,如果采用new构造器类创建Integer对象,则每次返回全新的Integer对
象,如果采用valueOf方法来创建Integer对象,则会缓存该方法创建的对象。