博客
关于我
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添加用户权限报1064 - You have an error in your SQL syntax问题解决
查看>>
mysql添加索引
查看>>
mysql添加表注释、字段注释、查看与修改注释
查看>>
mysql清理undo线程_MySQL后台线程的清理工作
查看>>
mysql清空带外键的表
查看>>
MySQL清空表数据
查看>>
mysql源码安装
查看>>
Mysql源码安装过程中可能碰到的问题
查看>>
MySQL灵魂16问,你能撑到第几问?
查看>>
MySQL灵魂拷问:36题带你面试通关
查看>>
mysql状态分析之show global status
查看>>
mysql状态查看 QPS/TPS/缓存命中率查看
查看>>
mysql生成树形数据_mysql 实现树形的遍历
查看>>
mysql用于检索的关键字_Mysql全文搜索match...against的用法
查看>>
MySQL用得好好的,为什么要转ES?
查看>>
MySql用户以及权限的管理。
查看>>
MySQL用户权限配置:精细控制和远程访问的艺术!------文章最后有惊喜哦。
查看>>
mysql用户管理、常用语句、数据分备份恢复
查看>>
MySQL留疑问:left join时选on还是where?
查看>>
mysql登陆慢问题解决
查看>>