博客
关于我
2.Android篇——利用SharedPreferences封装本地存储工具类
阅读量:486 次
发布时间:2019-03-07

本文共 2323 字,大约阅读时间需要 7 分钟。

问题:

有的时候我们一个查询的接口需要重复的请求多次,尽管每次返回的结果是一样的,但是还是需要请求多次,这个时候我们就可以再第一次请求的时候把数据存到我们的缓存中,之后的请求就可以直接调用缓存中没有过期的数据,这里我们奉上工具类代码:

package com.zjxf.utils;import android.content.SharedPreferences;public class SharedPrefUtils {	private static SharedPrefUtils instance;	private SharedPreferences sp;	private SharedPrefUtils() {		sp = BDApplication.getInstance().getSharedPreferences(				BDApplication.getInstance().getPackageName(), 0);	}	public static SharedPrefUtils getInstance() {		if (instance == null) {			synchronized (SharedPrefUtils.class) {				if (instance == null) {					instance = new SharedPrefUtils();				}			}		}		return instance;	}	public void putStr2SP(String key, String value) {		sp.edit().putString(key, value).commit();	}	public String getStrBykey(String key, String defValue) {		return sp.getString(key, defValue);	}	public void putInt2SP(String key, Integer value) {		sp.edit().putInt(key, value).commit();	}	public Integer getIntByKey(String key, Integer defValue) {		return sp.getInt(key, defValue);	}	public void putFloat2SP(String key, Float value) {		sp.edit().putFloat(key, value).commit();	}	public Float getFloatByKey(String key, Float defValue) {		return sp.getFloat(key, defValue);	}	public void putLong2SP(String key, Long value) {		sp.edit().putLong(key, value).commit();	}	public Long getLongByKey(String key, Long defValue) {		return sp.getLong(key, defValue);	}		public void putBoolean2SP(String key, boolean value) {		sp.edit().putBoolean(key, value).commit();	}		public Boolean getBooleanByKey(String key, boolean defValue) {		return sp.getBoolean(key, defValue);	}	public void remove(String key) {		try {			sp.edit().remove(key).commit();		} catch (Exception e) {			e.printStackTrace();		}	}}
package com.zjxf.utils;import android.app.Application;public class BDApplication extends Application {	private static BDApplication instance;		@Override	public void onCreate() {		super.onCreate();		instance = this;		CrashHandler.getInstance().init(this.getApplicationContext());	}		public static BDApplication getInstance(){		return instance;	}}

上面这个全局的类需要在AndroidManifest.xml里面设置一下

然后就可以使用了,用法如下:

SharedPrefUtils.getInstance().putStr2SP(CacheKeys.LOGIN_SESSION_Id, sessionId); //添加值 String schoolName = SharedPrefUtils.getInstance().getStrBykey(CacheKeys.THIS_SCHOOL_NAME, StringUtil.EMPTY_STRING); //获取值

 

转载地址:http://iaucz.baihongyu.com/

你可能感兴趣的文章
Mysql Can't connect to MySQL server
查看>>
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>
Multicast1
查看>>
MySQL Cluster 7.0.36 发布
查看>>
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>
MySQL Cluster与MGR集群实战
查看>>
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>