zoukankan      html  css  js  c++  java
  • 安卓C++代码crash时获取栈信息

    上篇提到因为全局对象没有初始化造成的windows上不crash但是安卓上会crash的问题其实就是个很简单的空指针问题。但是因为对安卓代码不熟悉,前后折腾了一个星期才发现。

    最开始的时候安卓手机是需要装个似乎叫GDB的工具才能调试的,但是据说很不好用,我没用过,然后其他同事能用的也很少。

    后来听说4.0以上的手机可以连eclipse调试了,喜大普奔的借了一台来,结果发现eclipse的adt版本太低,右键不出现debug as Android Application这个选项,于是升级。这类东西的升级向来都是噩梦,各种需要配套,而且速度经常还很慢,于是反复装反复升级,算是好了。

    中间还出来一个问题,跑的时候会报一个很奇怪的错,细节忘了,搜索之发现是要把一个什么东西加到eclipse的启动项目里。

    期间还有各种诡异问题,反正折腾了好久最后终于是能跑了,然后借不到能用的4.0的手机,之前那台不知道为啥说空间不够死活不让我装啊,同事出了个馊主意用91助手可以装到sd卡上,可是没用啊,如果要调试的话,人家还是会自己重新装。

    最后的最后,收到上述同事发来的邮件,终于解决问题。

    这个crash不好查的原因是因为并不会跟windows跑一样给你弹个框说空指针了,连xcode都不如,看log感觉他就默默的死掉了。不过有个线索是log里面会有一个像栈一样的信息,不过这个信息很低调,只能说感觉像栈,其实全是数字。但是呢,这个数字可以用ndk自带的工具addr2line还原出具体函数行号——这就够够的了啊。

    Ndk目录/toolchains/arm-linux-androideabi-4.6/prebuilt/windows/bin/arm-linux-androideabi-addr2line.exe -f -e XXX.so 0xXXXXXXXX

    就可以了。中间的版本什么的要和编译so的版本匹配,具体信息在eclipse里面是能看到的。结果我刚用的时候出来是??:??,请教之发现是因为我用的so不对,当时搜出来两个,应该用local下面那个,跟其他东西在一起的。然后当当当当就看到栈了,马上就定位好了问题。

    那个目录还有很多其他的工具,感觉也很有用,不过就没有深入发掘了。

  • 相关阅读:
    c# Linq及Lamda表达式应用经验之 GroupBy 分组
    页面加载完之后在执行js代码
    C#循环声明一个类
    通过文件流stream下载文件
    jquery validate如何不提交表单就做验证(ajax提交数据)
    用vs2012的命令利用xsd文件生成对应的C#类,把xml的string类型映射到生成的类
    用xsd验证xml
    MVC中如何跳过对模型中某个属性的验证
    用list<类>集合接收一个网址返回的一个类的集合的XML
    Mac 查看Volumes
  • 原文地址:https://www.cnblogs.com/unionfind/p/3417612.html
Copyright © 2011-2022 走看看