一、探寻原因
在一个复杂的layout嵌套较多layout的android界面。在Android 2.3、内存较低 的机型上,出现 java.lang.StackOverflowError 这个Exception,appcrash退出。

这个错误出现的比較奇怪,在我做技术调研的时候,这个界面是放在4.0的系统中測试,工作非常正常,没有出现这个严重错误。

       android SDK中对该错误的出现的场景描写叙述为:因为栈调用的层次太多。超过了虚拟器dalvik的最大限制(作为一个虚拟器參数,可定制)导致的。当程序编写错误导致无限递归调用时会触发,此外程序正确可是递归调用的层次过深也会触发。
       在寻找问题的过程中,採取排除法。一点点凝视代码。找到是由于语音控件的问题。去掉语音控件,不会出现Crash。观察该界面的集成情况,发现当加入语音控件后,又添加了一层layout, 此时已说明layout的嵌套已经达到最大值,不能容忍再加入1层。而由于该界面复杂,设计时, view的layout深度为6层。

原因定位为界面嵌套层次过深,初步认定解决方式为降低layout层次。

 
二、解决方法
         解决嵌套过深的基本思路是在实现相同的效果的前提下降低界面的layout深度。

在我将layout深度由6层精简为4层,该错误被解决。

SDK提供的解决方法有:
1)       多用RelativeLayout的各种布局属性来完毕布局,而避免过多使用嵌套layout来实现。
   2)       占位或填充剩余空间的元素多用View,避免使用layout等viewGroup。
final 方法有:
由于咱的View层次的确须要非常多,所以从改变View层次入手非常难,開始纠结了非常久,最终找到突破口。在Android官方SDK提供了一种XML标签, 在官方文档里的标注就是通过merge标签来降低视图层级结构。

      这个问题暂且如此解决吧,开发中注意不要在现有深度上添加深度。

同一时候继续寻找进一步解决方式。


总结下,从实际的数据来看,设计中layout嵌套深度超过10层(假设要兼容低端机型,最好不要超过5层)。就应该考虑下优化了,否则就会出现java.lang.StackOverflowError的crash了。

Android慎用layout嵌套, 尽量控制在5层下面java.lang.StackOverflowError的更多相关文章

  1. android布局太深导致的 java.lang.StackOverflowError

    E/AndroidRuntime( 1900): java.lang.StackOverflowError E/AndroidRuntime( 1900):     at android.graphi ...

  2. 【Android】java.lang.StackOverflowError: stack size 8MB

    最近遇到的问题,报了两个错误,如下: java.lang.StackOverflowError: stack size 8MB android.os.TransactionTooLargeExcept ...

  3. Android ADT插件更新后程序运行时抛出java.lang.VerifyError异常解决办法

    当我把Eclipse中的 Android ADT插件从21.1.0更新到22.0.1之后,安装后运行程序抛出java.lang.VerifyError异常. 经过调查,终于找到了一个有效的解决办法: ...

  4. android 使用讯飞人脸识别api报错:java.lang.UnsatisfiedLinkError

    1.在做一个人脸识别的项目,使用的是讯飞的api,编辑器为AS2.0,运行时报如下错误: FATAL EXCEPTION: main                  Process: com.adm ...

  5. Android native进程间通信实例-binder篇之——HAL层访问JAVA层的服务

    有一天在群里聊天的时候,有人提出一个问题,怎样才能做到HAL层访问JAVA层的接口?刚好我不会,所以做了一点研究. 之前的文章末尾部分说过了service call 可以用来调试系统的binder服务 ...

  6. android开发解决Error:Execution failed for task ':app:transformDexArchiveWithExternalLibsDexMergerForDebug'. > java.lang.RuntimeException: java.lang.RuntimeException: c.....

    网上常见的方法我都试过,都没能解决,偶然看到的一个方法解决了,在这了记录一下. 在App目录下的build.gradle的android{ ...  ....}中添加如下代码,即可解决.(xx.xx. ...

  7. 关于viewpager 里嵌套 listview 同时实现翻页功能的“java.lang.IllegalStateException: The specified child..."异常处理

    这几天做项目用到了ViewPager,因为它可以实现左右划动多个页面的效果,然后 再每个页面里使用ListView,运行时总是出现”PagerAdapter java.lang.IllegalStat ...

  8. android java.lang.StackOverflowError

    转自:http://hi.baidu.com/424660053/item/bee53a2633870dccddf69a17 最近做项目出现一个java.lang.StackOverflowError ...

  9. Android 运行 gson.toJson(object) 报java.lang.StackOverflowError异常

    如以下的代码,运行后报java.lang.StackOverflowError错误: MusicSavedInfo musicSavedInfo=new MusicSavedInfo(currentS ...

随机推荐

  1. HTML5的data-*自己定义属性

    HTML5添加了一项新功能是自己定义数据属性.也就是data-*自己定义属性.在HTML5中我们能够使用以data-为前缀来设置我们须要的自己定义属性,来进行一些数据的存放.当然高级浏览器下可通过脚本 ...

  2. oc24--description

    // Person.h #import <Foundation/Foundation.h> @interface Person : NSObject { int _age; double ...

  3. Android下添加新的自定义键值和按键处理流程【转】

    本文转载自: Android下添加新的自定义键值和按键处理流程     说出来不怕大家笑话,我写这篇博客的原因在于前几天去一个小公司面试Android系统工程师,然后在面试的时候对方的技术总监问了我一 ...

  4. CodeForces 651C

    Description Watchmen are in a danger and Doctor Manhattan together with his friend Daniel Dreiberg s ...

  5. openssl https证书

    今天摸索了下 HTTPS 的证书生成,以及它在 Nginx 上的部署.由于博客托管在 github 上,没办法部署证书,先记录下,后续有需要方便快捷操作.本文的阐述不一定完善,但是可以让一个初学者了解 ...

  6. 查看 myeclipse激活状态

    查看激活状态  myeclipse-->subscription information

  7. 解决生成主键 id重复的解决办法

    作者:董春秋链接:https://www.zhihu.com/question/30674667/answer/49082988来源:知乎著作权归作者所有,转载请联系作者获得授权. 全局id生成器.我 ...

  8. ios - masonry第三方库使用自动布局(参考:http://www.cocoachina.com/ios/20141219/10702.html)

    #import "ViewController.h" #import "Masonry.h" #define kWeakSelf(weakSelf) __wea ...

  9. css3中的animation属性

    作用:通过给元素添加animation属性,可以赋予该元素动画效果. <!DOCTYPE html><html>    <head>        <styl ...

  10. 第三课 创建函数 - 从EXCEL读取 - 导出到EXCEL - 异常值 - Lambda函数 - 切片和骰子数据

    第 3 课   获取数据 - 我们的数据集将包含一个Excel文件,其中包含每天的客户数量.我们将学习如何对 excel 文件进​​行处理.准备数据 - 数据是有重复日期的不规则时间序列.我们将挑战数 ...