最近项目中发现,欢迎页阅读存储sp以及勾选登陆前隐私条款保存的sp读取失效(实际未存储)问题。
正常现象:欢迎页引导viewpger阅读完,保存已阅读状态,下次不再展示。
bug现象:viewpager引导页阅读完,保存sp,进入主流程。杀掉进程,依旧再次进入引导页viewpager。
原因:使用了服务进程上传日志文件,保存了sp数据(与主进程保存viewpager引导页的是同一个sp文件),造成主进程保存实际不成功,但在杀进程前可以获取到保存的值是对的,应该是从内存读取的。
测试:
以下demo情况100%复现:
1.清空sp文件
2.启动服务进程,服务进程保存自己的key-value,sp文件名为“test”;
3.主进程在服务进程保存完后保存自己的key-value,使用同一个sp文件,即“test”,此时读取sp,获取值正常
4.主进程保存值完后,再通知服务进程保存自己的值,我这里采用更新同一个key,即修改服务进程第一次保存的值,此时在主进程中,依然可以正确获得主进程自己保存的value值
5。杀掉进程重启,获取主进程之前保存的key-value值,发现获取到的是getString所填的默认值。打开studio设备管理器查看sharePreference的test文件,发现主进程保存的key不见了。
方案:服务进程保存的值,如果只有服务进程自己使用,最好单独使用一个sp文件存储;如果其他进程也需要使用建议采用ContentProvider或者其他方案实现。
具体底层实现原理未去研究,特此记录。