关于Android

优雅的存储你的数据

2017-06-05  本文已影响73人  吴鸿飞

当每次写代码时有没有一种到处都是数据,使用的时候需要到处传递的感觉。比如我有一份数据,有好几个页面都需要使用,好的做法并不是在第一次使用时去请求,在后边不停的去传递。类似于activity的context,可以将之提取成一个单例,在这个单例中去操作这些数据。

之前都是自己写了一个单例,然后每个数据都写一个属性放在其中,这太有损程序猿的威风。

所以自己将数据放在了map中,并且根据存储的Class对象分类存放。

使用时根据需要的Class对象从map中去取,map放在了单例之中。

也就是整个程序各处都可以使用。

当然依然可以添加缓存,缓存与否根据自己的需要来做,可以在设置数据之后直接设置缓存。

联网获取数据之后直接将数据转化为jsonobject,放入存储。当需要使用时直接去取即可。

上边的东西都都已经写在了我封装的库中,并且做了两个版本使用,

一个版本只有数据的存储,其他的缓存联网都没有做,根据自己的需要使用,

另外一个版本添加了联网,联网之后的数据转换,以及缓存的处理。

不多说放个链接看看。

存储数据库

使用及其简单,看看基本都会了,大概的说说

取数据,使用  StoreData.getStore().getDatas(DataBean.class,null);

最后一个是回调,取数据取不到时留下这个回调函数,当数据有时会来通知取数据的一方来再次取数据,回调函数中可以设置是否每次刷新都通知来取。可以随时自己不需要时将回调函数清除,当然需要这个引用。

还有另外一种,取数据的方式StoreData.getStore().getDatas(tag,DataBean.class,null);为取得数据设置tag,obj类型的,随便你设置。

当不需要时,根据tag直接清空取数据的引用。防止内存泄露。

现在还又几个问题需要修复的。

一、清除数据的接口还没有写,但是可以使用单例中的方法直接将其制为空

二、数据设置的顺序没有好好思量,可以根据头的时间设置,先返回的不能更新后返回的。

三、本地数据不能更新联网数据

四、缓存的设置没有很好的思量

五、数据一直没有到达时是否需要一直存在回调对象等待数据更新

这样存放数据的意义:

我思考的这样存放数据,最重要,可以将存数据与取数据分开,我存数据可以不考虑数据是否有人需要,只要未来有人有可能需要就可以存放,当然这里存放的数据尽量是小的数据,大数据不适合长期存放。取数据也不需要考虑有没有数据,我只需要每次实现有数据和没有数据的的接口即可。当然这里联网请求的进度条就有了一些问题,但是也不是很大。

这里只是提出了这么一种想法,希望可以抛砖引玉。也可以让自己有所突破

欢迎大家指正,欢迎大家批评。

技术只有不断的改正才能有所提升。

上一篇下一篇

猜你喜欢

热点阅读