android 高级开发工程师面试题

本文探讨了Android应用的性能分析,包括遍历测试和网络性能测试,以及如何通过自动化测试来提高效率。同时,文章深入讲解了内存泄露的原因,如Context使用不当、非静态内部类的静态实例等,并提供了避免内存泄露的方法。针对OOM异常,提出了处理大图片、避免界面切换导致的问题、正确管理数据库游标和Adapter的建议。最后,文章提到了Android中捕获未捕获异常的方法,包括自定义CrashHandler和使用第三方服务。
摘要由CSDN通过智能技术生成

1、 如何对 Android 应用进行性能分析
1)app产品做好之后必须从每个控件在国内不同的手机品牌和不同系统版本进行兼容性测试,业内也叫遍历测试,所谓的遍历测试是可以移动识别应用的控件从而进行多层次的运行测试,当中包含了安装测试,启动测试,控件遍历测试,最后是卸载测试!
2)兼容性测试,也就是适配测试完成之后需要开始对网络性能进行测试,这里大概有几个方面需要进行的:网络性能测试,元素加载性能测试,网络可用性测试等等! 国内现有的测试周期和测试手段都是通过人工化测试,真正实现自动化又节省时间与人力的只有借助第三方应用性能管理提供商才可以实现!
2、 什么情况下会导致内存泄露
1)Context使用不当造成内存泄露;不要对一个Activity Context保持长生命周期的引用(譬如上面概念部分给出的示例)。尽量在一切可以使用应用ApplicationContext代替Context的地方进行替换
2)非静态内部类的静态实例容易造成内存泄漏;即一个类中如果你不能够控制它其中内部类的生命周期(譬如Activity中的一些特殊Handler等),则尽量使用静态类和弱引用来处理(譬如ViewRoot的实现)。
3)警惕线程未终止造成的内存泄露;譬如在Activity中关联了一个生命周期超过Activity的Thread,在退出Activity时切记结束线程。一个典型的例子就是HandlerThread的run方法是一个死循环,它不会自己结束,线程的生命周期超过了Activity生命周期,我们必须手动在Activity的销毁方法中中调运thread.getLooper().quit();才不会泄露。
4)对象的注册与反注册没有成对出现造成的内存泄露;譬如注册广播接收器、注册观察者(典型的譬如数据库的监听)等。
5)创建与关闭没有成对出现造成的泄露;譬如Cursor资源必须手动关闭,WebView必须手动销毁,流等对象必须手动关闭等。
6)不要在执行频率很高的方法或者循环中创建对象,可以使用HashTable等创建一组对象容器从容器中取那些对象,而不用每次new与释放。
7)避免代码设计模式的错误造成内存泄露。
3、 如何避免 OOM 异常
1)图片过大导致OOM
Android 中用bitmap 时很容易内存溢出, 比如报如下错误:
Java.lang.OutOfMemoryError : bitmap size exceeds VM budget。
解决方法:
方法1: 等比例缩小图片

BitmapFactory.Options options = new BitmapFactory.Options();
options.inSampleSize = 2;
//Options 只保存图片尺寸大小,不保存图片到内存
B
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值