SharedPreferences sharedPreferences = getSharedPreferences("peopel", Context.MODE_PRIVATE); Editor editor = sharedPreferences.edit();//获取编辑器 editor.putString("name", "张三"); editor.putInt("age", 4); editor.commit();//提交修改
因为
SharedPreferences背后是使用
xml文件保存数据,getSharedPreferences(name,mode)方法的第一个参数用于指定该文件的名称,名称不用带后缀,后缀会由
Android自动加上。方法的第二个参数指定文件的操作模式,共有四种操作模式,这四种模式前面介绍使用文件方式保存数据时已经讲解过。如果希望
SharedPreferences背后使用的
xml文件能被其他应用读和写,可以指定定
Context.MODE_WORLD_READABLE和Context.MODE_WORLD_WRITEABLE权限。
另外
Activity还提供了另一个
getPreferences(mode)方法操作SharedPreferences,这个方法默认使用当前类不带包名的类名作为文件的名称。
SharedPreferences sharedPreferences = getSharedPreferences("zyj", Context.MODE_PRIVATE); //getString()第二个参数为缺省值,如果preference中不存在该key,将返回缺省值 String name = sharedPreferences.getString("name", ""); int age = sharedPreferences.getInt("age", 1);
使用SharedPreferences存List对象:
先将其转换成json字符串然后储存。
储存:
mSearchGroupSP=context.getSharedPreferences("search_history_group_date",Context.MODE_PRIVATE); SharedPreferences.Editor editor=mSearchGroupSP.edit(); Gson gson=new Gson(); String json=gson.toJson(strings); editor.putString("group_history_date",json ); editor.commit();
获取:
String json=mSearchGroupSP.getString("group_history_date",null); if(json!=null){ Gson gson=new Gson(); Type type = new TypeToken<List<String>>(){}.getType(); List<String>mlist=gson.fromJson(json,type); return mlist; }