有時候經常進行一些不連續的重複的操作.這就需要用到歷史記錄來快速的進行操作了.
關於歷史記錄的存儲讀寫,我寫了個小方法.如下:
point 是起指向作用,指向最舊的記錄.比如有N條記錄(最多),1~N,寫入一條記錄後point=(point+1)%N;讀取時最新的記錄在前面.

下面是存儲路徑的歷史記錄的實現方法:


List<String> readHistory(){




List<String> list= new ArrayList< String>();
CoNtext ctx =this;
SharedPreferences SAVE = ctx.getSharedPreferences("save", MODE_PRI加值稅E);
int point=SAVE.getInt("point", 0);
String path;
final int N=16;
for(int i=0,n=point;i<=N;i++){
path=SAVE.getString("path"+n, null);
if(path!=null){
list.add(path);
}

n=n>0?(--n):(--n+N)%16;
}
return list;
}


void writeHistory(String path){
CoNtext ctx = this;
SharedPreferences SAVE = ctx.getSharedPreferences("save", MODE_PRI加值稅E);
int n=SAVE.getInt("point", 0);
Editor editor = SAVE.edit();
editor.putString("path"+n, path);
editor.putInt("point",( n+1)%16);
editor.commit();
}



最後用清單列出來即可.
創作者介紹
創作者 shadow 的頭像
shadow

資訊園

shadow 發表在 痞客邦 留言(0) 人氣()