博客
关于我
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查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
查看>>
MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
查看>>
mysql查询超时对PHP执行的影响
查看>>
mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
查看>>
mysql查询过程
查看>>
MySQL模拟Oracle序列sequence
查看>>
Mysql模糊查询like效率,以及更高效的写法
查看>>
MySQL死锁套路:一次诡异的批量插入死锁问题分析
查看>>
Mysql死锁问题Deadlock found when trying to get lock;try restarting transaction
查看>>
mysql每个数据库的最大连接数_MySQL数据库最大连接数
查看>>
Mysql流程控制结构,if函数、case结构、if结构、循环结构
查看>>
mysql添加外网访问权限
查看>>
mysql添加用户
查看>>
MySQL添加用户、删除用户与授权
查看>>
mysql添加用户及权限
查看>>
Mysql添加用户并授予只能查询权限
查看>>
mysql添加用户权限报1064 - You have an error in your SQL syntax问题解决
查看>>
mysql添加索引
查看>>
mysql添加表注释、字段注释、查看与修改注释
查看>>
mysql清理undo线程_MySQL后台线程的清理工作
查看>>