老自验中有一个判断验货途径的字段,isSimulator是否是模拟器,该字段是存储在object类的deviceService类中,结构如下所示:
object DataConfig {
@JvmStatic
val deviceService: DeviceService = DeviceService()
}
class DeviceService(
//是否是模拟器
var isSimulator: Boolean = false,
// 设备识别,用于日志,本地保存
var uniqueId: String? = null,
)
它的初始化在登录页面。每次接口请求时,都会将这个参数带给后台。
- 从线上记录的日志看,一开始
isSimulator
一直都是true
,但某个时刻,isSimulator
突然变成了false
。而且在这期间,通过日志来看,用户并没有换设备重新登录。 -
isSimulator
值只在登录页面登录时才会去检测并初始化,其它地方并没有去初始化。所以正常情况来看,在使用过程中isSimulator
的值不可能会改变。 - 用户使用的是
海马玩模拟器
,Android
版本是4.2.2
- 查看崩溃日志,使用期间APP并没有崩溃
初步怀疑:
- 应用的进程被系统在某种情况下杀死并随后又重建了。导致静态变量的值丢失了。
解决方案: - 登录时检查完成后,将该值存储在本地
疑问: - 与
isSimulator
在同一级的字段还有uniqueId
,这个字段并没有清空,所以对上面的结论还是有疑问。