SharedPreferences 存List集合,模拟数据库,随时存取
PS:SharedPreferences只要稍微学过一点就会用,他本身通过创建一个Editor对象,来存储提交,而editor可以存的格式为
他里面可以存一个Set<String>
Set<String> list=new HashSet<>();
list.add("111");
list.add("111");
editor.putStringSet(keyStr,list);
HashSet是Java中非常常用的数据结构对象,HashSet是通过HashMap实现的,TreeSet是通过TreeMap实现的,只不过Set用的只是Map的key 。这里有hashset百度百科,不懂的可以看看https://baike.baidu.com/item/HashSet/8887897?fr=aladdin。
Set也是一个集合,但是该集合不能存重复的值,不像list集合那样常用,但是SP只能存放Set,不能直接存放List,但是我们可以把他转换成字符串,读取的时候把字符串再转变成List就可以,我之前参加国赛的时候,就会用到很多数据,之前都是写SQLite,但是SQLite不是很好管理,而且,存的东西非常少的时候,再写SQLite就感觉到没必要了,所以,就写了这样一个转换类。
写入:字符串-->List集合
读取:List集合-->字符串
方法一
该方法不依赖外部jar包,就是没有网络也是可以做了,但方法二是需要添加一个依赖,就是GSON。
1:我写的是List<Object[]> ,只要是该形式,Object的长度是多少都行。(当然不能超过限制)
package day1.cn.ceshi001; import android.content.Context;
import android.content.SharedPreferences;
import android.util.Log; import java.util.ArrayList;
import java.util.List; /**
* Created by liuzhitong on 2017/6/6.
*
* @Author : liuzhitong
* @Description :
*/ public class ListOrStrTools {
public Context context;
public String spStr,keyStr;
private final SharedPreferences sp1;
private Object[] obj; public ListOrStrTools(Context context, String spStr, String keyStr) {
this.context = context;
this.spStr = spStr;
this.keyStr = keyStr;
sp1 = context.getSharedPreferences(spStr,0);
} public void setData(List<Object[]> lis){ //存入之前要先把之前的数据拿出来
String str="";
String s=sp1.getString(keyStr,"404");
if(s.equals("404")){
Log.e("sp添加出错","404");
}
else{str+=s;}
if(lis.size()==0){
Log.e("sp----lis","0");
}
//转换List集合---->字符串
else{
for(int i=0;i<lis.size();i++){
//检测list<Object[]>中的object对象的长度
for(int j=0;j<lis.get(i).length;j++){
str+=lis.get(i)[j]+"[&]";
} str+="[^]";
}
SharedPreferences.Editor editor=sp1.edit();
editor.putString(keyStr,str); editor.commit();
}
} public List<Object[]> getData(){
List<Object[]> li1=new ArrayList<>(); String s=sp1.getString(keyStr,"404");
if(s.equals("404")){
Log.e("读取出错","404");
return li1;
}
//字符串---->List集合
else{
String data1[]=s.split("\\[\\^\\]");
for(int i=0;i<data1.length;i++){
String da1[]=data1[i].split("\\[\\&\\]");
int num=da1.length;
obj = new Object[num];
for(int j=0;j<num;j++){
obj[j]=da1[j];
}
li1.add(obj);
}
return li1;
} }
}
2:调用该类
ListOrStrTools listOrStrTools = new ListOrStrTools(this, "info", "li1");//参数分别是:this(本类上下文),模拟数据库名字,表名。想当于 sp1 = context.getSharedPreferences(spStr,);
List<Object[]> li = new ArrayList<>();
for (int i = 0; i < 3; i++) {
objects = new Object[4];
objects[0] = i;
objects[1] = "11";
objects[2] = "22";
objects[3] = "333";
li.add(objects);
} ListOrStrTools listOrStrTools = new ListOrStrTools(this, "info", "li1");
listOrStrTools.setData(li);
List<Object[]> list1 = listOrStrTools.getData();//取出数据,并返回一个list集合。
Log.e("ssss", list1.get(0)[3] + "");
for (int i = 0; i < list1.size(); i++) {//打印存入的集合
for (int j = 0; j < list1.get(i).length; j++) {
Log.e("sss", list1.get(i)[j] + "");
}
}
结果成功取出
完
方法二:
利用gson这个依赖把字符串或者list转成json字符串格式存入sp中,然后操作的时候也是用sp拿出刚才存入的json字符串,修过之后再存入,麻烦归麻烦,封装成方法,麻烦一次终身受益。
添加依赖 app->build.gradle
implementation 'com.google.code.gson:gson:2.8.1'//compile(studio3.0之前)和implementation(3.0之后)
数据转成JSON字符串
UserBean userBean;
List<UserBean> list = new ArrayList<>();
for(int i=0;i<3;i++){
userBean = new UserBean();
userBean.setAge(10);
userBean.setName("小王");
list.add(userBean);
}
Gson gson=new Gson();
String listStr = gson.toJson(list);
把结构listStr存入sp。
取出数据(List集合)
先看源码,传入一个JSON字符串,第二个参数要求是什么类型,可以是list集合,泛型等。
public <T> T fromJson(String json, Type typeOfT) throws JsonSyntaxException {
if (json == null) {
return null;
}
StringReader reader = new StringReader(json);
T target = (T) fromJson(reader, typeOfT);
return target;
}
取出
List<UserBean> lis = gson.fromJson(listStr,new TypeToken<List<UserBean>>(){}.getType());
SharedPreferences 存List集合,模拟数据库,随时存取的更多相关文章
- php模拟数据库常用操作效果
test.php <?php header("Content-type:text/html;charset='utf8'"); error_reporting(E_ALL); ...
- MongoDB文档、集合、数据库简介
文档 概述 文档是MongoDB的核心概念,是数据的基本单元,非常类似于关系数据库中的行.在MongoDB中,文档表示为键值对的一个有序集.MongoDB使用Javascript shell,文档的表 ...
- cache—主存—辅存三级调度模拟
近日,在体系结构的课程中,老师留了一个上机作业,为cache—主存—辅存三级调度模拟,要求如下: 实现三级存储体系的模拟调度程序 描述:CPU在cache访问数据块,若命中给出对应的cache实地址, ...
- JavaEE学习之Spring Security3.x——模拟数据库实现用户,权限,资源的管理
一.引言 因项目需要最近研究了下Spring Security3.x,并模拟数据库实现用户,权限,资源的管理. 二.准备 1.了解一些Spring MVC相关知识: 2.了解一些AOP相关知识: 3. ...
- laravel进行单元测试的时候如何模拟数据库以及mockery的调用
单元测试是独立的,所谓的独立是指有独立的运行容器,独立的数据库. 这样做有什么好处呢? (1). 不会跟正常的容器产生冲突,继而影响正常业务. (2). 数据库独立防止数据被修改影响单元测试结果. 这 ...
- C#将图片存放到SQL SERVER数据库中的方法
本文实例讲述了C#将图片存放到SQL SERVER数据库中的方法.分享给大家供大家参考.具体如下: 第一步: ? 1 2 3 4 5 6 7 8 9 10 //获取当前选择的图片 this.pictu ...
- MongoDB的文档、集合、数据库(二)
为了理解MongoDB的名词,可以将其于关系型数据库进行对比: 一.文档 概述 文档是MongoDB的核心概念,是数据的基本单元,非常类似于关系数据库中的行.在MongoDB中,文档表示为键值对的一个 ...
- Java基础面试操作题:线程同步代码块 两个客户往一个银行存钱,每人存三十次一次存一百。 模拟银行存钱功能,时时银行现金数。
package com.swift; public class Bank_Customer_Test { public static void main(String[] args) { /* * 两 ...
- MongoDB 学习笔记之 删除数据,集合,数据库
删除数据,集合,数据库: 删除一个文档: db.media.deleteOne({"name": "Sky"}) 删除多个文档: db.media.delete ...
随机推荐
- 常用的redis命令
常用的redis命令 http://www.runoob.com/redis/redis-tutorial.html 菜鸟教程 Cmd连接有密码的redis:$ redis-cli -h ho ...
- gdb的多线程调试
info threads 可以查看当前进程有哪些线程 thread ID 可以切换到线程ID bt 查看当前线程堆栈 set scheduler-locking on多线程调试过程中, 线程会来回切换 ...
- String、StringBuilder和StringBuffer
1.string不可变性 java的docs有这样一句话:Strings are constant; their values cannot be changed after they are cre ...
- 2017最新PHP初级经典面试题目汇总(下篇)
17.isset.empty.is_null的区别 isset 判断变量是否定义或者是否为空 变量存在返回ture,否则返回false 变量定义不赋值返回false unset一个变量,返回false ...
- C# 通过反射初探ORM框架的实现原理
背景: 以前学的Java进行开发,多用到Mybatis,Hiberante等ORM框架,最近需要上手一个C#的项目,由于不是特别难,也不想再去学习C#的ORM框架,所以就想着用反射简单的实现一下ORM ...
- 5、C#基础 - C#的值类型
1.C#的值类型 有几个特点: 存储在栈里 基于值类型的变量直接包含值(值类型存储实际值). 将一个值类型变量赋给另一个值类型变量时,将复制包含的值. 这与引用类型变量的赋值不同,引用类型变量的赋值只 ...
- 使用PowerApps快速构建基于主题的轻业务应用 —— 入门篇
作者:陈希章 发表于 2017年12月12日 前言 在上一篇文章 基于Office 365的随需应变业务应用平台 中我提到,随着随需应变的业务需要,以及技术的发展,业务应用的开发的模式也有了深刻的变化 ...
- django模板语法之include
假如我们有以下模板index.html,代码为: <!DOCTYPE html> <html lang="en"> <head> <met ...
- Android HandlerThread 源码分析
HandlerThread 简介: 我们知道Thread线程是一次性消费品,当Thread线程执行完一个耗时的任务之后,线程就会被自动销毁了.如果此时我又有一 个耗时任务需要执行,我们不得不重新创建线 ...
- 二叉树的递归遍历 Tree UVa548
题意:给一棵点带权的二叉树的中序和后序遍历,找一个叶子使得他到根的路径上的权值的和最小,如果多解,那该叶子本身的权值应该最小 解题思路:1.用getline()输入整行字符,然后用stringstre ...