引入:

Android静态变量的生命周期遵守Java的设计。静态变量在类被load的时候分配内存,并存在于方法区。当类被卸载时,静态变量被销毁。在PC机的客户端程序中,一个类被加载和卸载,可简单的等同于JVM进程的启动和结束。在Android中,用的DVM也是一样的,不过Android中不太突出进程的概念,所以对静态变量的生命周期就是感觉模糊,这种模糊对于值类型是无所谓的,如果是静态的对象引用,则与内存回收、内存泄露这些问题有关,有必要加深研究和理解。

一、静态变量在类被加载的时候分配内存

类在什么时候被加载?
当我们启动一个App的时候,系统会创建一个进程,此进程会加载一个DVM实例,然后代码就运行在DVM之上,类的加载和卸载、垃圾回收等事情都由DVM负责。也就是说进程启动的时候,类被加载,静态变量被分配内存。

二、静态变量在类被卸载的时候销毁

类在什么时候被卸载?在进程结束的时候。

说明:一般情况下,所有的类都是默认的ClassLoader加载的,只要ClassLoader存在,类就不会被卸载,而默认的ClassLoader生命周期是与进程一致的,这里讨论一般情况。

三、Android的进程什么时候结束

这个是Android对进程和内存管理不同于PC的核心。如果资源足够,Android不会杀掉任何进程,另一个意思是进程随时可能会被杀掉。而Android会在资源足够的时候,重启被杀掉的进程。也就是说静态变量的值,如果不做处理,是不可靠的,可以说内存中的一切都不可靠,如果要可靠,还是保存到SharedPreferences或者SD卡中去,在重启的时候恢复回来。

另一个种情况就是不能把退出所有Activity等同于进程的退出,所以在用户点击图标启动应用的时候,以前存放于静态变量中的值,有可能还存在,因此要视具体情况给予清空操作。

四、Application也是一样不可靠

Application其实是一个单例对象,也是放在内存中的,当进程被杀掉,就全清空了,只不过Android系统会帮重建Application,而我们存放在Application的数据自然就没有了,还是得自己处理。

五、静态引用的对象会不会被回收?

在除了Android之外的Java运行环境中,你只要关心进程生命周期,在进程生命周期内你可以放心地使用静态变量来保持数据。只要静态变量没有被销毁也没有置null,其对象一直被保持引用,因此不会被垃圾回收。因此单例对象在运行时不会被回收。但是Android里它随时会被系统置NULL。

六、总结:

Android中,我们不知道何时进程会被kill,所以:

  • 不能保证静态变量会一直存在。(进程可能被Kill掉)
  • 每次打开app时静态变量的值都是初始值(进程没有被kill掉所有静态变量保存的还是上次的值)。
  • 而静态变量是不会被垃圾回收的,其对象一直保持引用

更多相关文章

  1. 深入探索Android稳定性优化
  2. android OOM
  3. Android中的UID和PID意义,及查看方式
  4. Android源码分析之WindowManager.LayoutParams属性更新过程
  5. Android(安卓)IPC机制(三)在Android(安卓)Studio中使用AIDL实现跨
  6. Android中的服务(service)详解(三)--远程服务(remote)
  7. Android静态变量的生命周期
  8. Android构建模块
  9. [Android官方API阅读]___

随机推荐

  1. listView 取消点击背景
  2. Android移植之dropbear
  3. gdb+gdbserver调试android的so文件
  4. Android(安卓)RecyclerView利用Glide加载
  5. android - Gesture学习 1
  6. Android(安卓)HAL层与Linux Kernel层驱动
  7. Android(安卓)Studio NDK项目移植问题 re
  8. Android——详解Paint的setPathEffect(Pa
  9. Android(安卓)各个版本区别及如何选择
  10. jadx:好用的反编译工具