内存泄漏导致内存溢出(OOM)

开发中遇到这样一个bug,调整之前做的一个意见反馈页面布局,输入框中限制字数200字,超过时自动删除不显示。

自定义了一个可监听并限制输入字数的EditText,贴上代码

 

 

 



 

测试过程中发现如果一次性往输入框中粘贴几百上千个文字时程序就会闪退,报的错误是

上网查了一下这个错误的意思是栈满溢出的错误。查看错误行的代码为第62行的delete方法,又重新测试了几次发现,如果输入字数达到限制字数200个之后一个一个字符输入或者一次粘贴比较少的字符是不会报异常的。最后确定了这个bug的原因:由于代码中调用delete方法时传入的变量值逻辑上不正确导致每次只删除一个字符,而一次性粘贴几百个甚至上千个字符过来的时候就要调用delete方法几百上千次,最终导致此异常发生。果断注掉,改为63行就好了。

 

考虑了一下觉得这个异常跟内存泄漏导致的内存溢出OOM特别的像,就一并记录一下。

内存泄漏是指你向系统申请分配内存进行使用,用完之后却没有释放,而导致这部分内存丢失,系统也不能把它在分配给其他需要的程序使用。

内存溢出是指程序申请的内存空间不够其使用而导致溢出。

一次的内存泄漏可能不会有太大的影响,对于用户来说也不会感觉的到也不会报异常。但是短时间内大量的内存泄漏堆积必然会导致内存溢出而报OOM异常。

ps:所以做开发的大家一定要注意平时的内存优化,毕竟你的作品就像你的孩子一样,老是无缘无故挂掉可不太好。

                                                                        

 

 

 

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
测试程序的内存泄漏内存溢出OOM(Out of Memory)和ANR(Application Not Responding)是为了确保程序在使用内存和响应用户输入时的稳定性和可靠性。 内存泄漏是指程序中已经不再使用的内存没有被正确释放,导致内存的占用不断增加,最终可能导致程序崩溃。为了测试内存泄漏,可以创建一个长时间运行的程序,并通过监测内存使用情况来判断是否有内存泄漏。可以使用内存分析工具来检测未被垃圾回收器回收的对象,以及通过分析堆转储文件来查找内存泄漏的源头。 内存溢出是指程序在申请内存时,无法分配到足够的内存空间,导致程序崩溃。为了测试内存溢出,可以通过申请大量的内存空间来触发溢出,或者通过无限制地生成对象导致内存快速占满。可以使用性能测试工具来模拟大量并发请求和数据量,以模拟真实环境中的内存使用情况,从而找出内存溢出的问题。 OOM是指由于内存不足导致程序无法继续分配内存空间而崩溃。为了测试OOM,可以通过限制程序可用内存的上限,观察程序在分配内存时是否能够正常运行,当内存达到上限时,是否能够优雅地处理内存不足的情况。 ANR是指应用程序无法在规定的时间内响应用户的输入事件,导致系统认为应用程序无响应而弹出ANR对话框。为了测试ANR,可以创建一个需要执行较长时间的代码块,来模拟应用程序无法及时响应用户输入的情况。可以通过监测主线程的响应时间来判断是否出现ANR。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值