0.2. android内存泄漏,举个例子
- 意思:该被释放的对象没有释放,一直被某个或某些实例所持有却不再被使用导致 GC 不能回收。
- 内存泄漏对象的两个特点
- 这些对象是可达的,即在有向图中,存在通路可以与其相连
- 这些对象是无用的,即程序以后不会再使用这些对象。
- 常见内存泄漏汇总
- 单例造成的内存泄漏
- 解决办法:getApplicationContext()
- 非静态内部类创建静态实例造成的内存泄漏
- 解决办法:将该内部类设为静态内部类或将该内部类抽取出来封装成一个单例
- handler造成的内存泄漏
- handler生命周期和handler不一致,因此这种实现方式一般很难保证跟 View 或者 Activity 的生命周期保持一致,故很容易导致无法正确释放。
- 创建一个静态Handler内部类,然后对Handler持有的对象使用弱引用,这样在回收时也可以回收Handler持有的对象
- 单例造成的内存泄漏
1. Activity与Fragment的生命周期
和activity类似(本本上有)
2. 四种Activity启动方式与特点
- standard
- 默认创建一个新的实例。
- singleTop
- 可以有多个实例,但是不允许多个相同Activity叠加
- singleTask
- 只有一个实例,若Activity不存在,则会在当前task创建一个新的实例,若存在,则会把task中在其之上的其它Activity destory掉并调用它的onNewIntent方法。。
- singleInstance
- 并且这个实例独立运行在一个task中,这个task只有这个实例,不允许有别的Activity存在。
3. Activity缓存方法。
- 有a、b两个Activity,当从a进入b之后一段时间,可能系统会把a回收,这时候按back,执行的不是a的onRestart而是onCreate方法,a被重新创建一次,这时a中的临时数据和状态可能就丢失了。
- 可以用Activity中的onSaveInstanceState()回调方法保存临时数据和状态,这个方法一定要在活动被回收之前调用。
21. Android内存优化方法:ListView优化,及时关闭资源,图片缓存等等
- listview优化
- 优化getView()方法,不要在其中写过多的逻辑代码
- 使用ViewHolder,减少了很多不必要的view创建。
- 滑动的时候不加载图片
- 将ListView的scrollingCache和animateCache设置为false。