• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

安卓C++代码crash时获取栈信息

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

上篇提到因为全局对象没有初始化造成的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下面那个,跟其他东西在一起的。然后当当当当就看到栈了,马上就定位好了问题。

 

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

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C#.NET中如何使用GetCursorPos函数发布时间:2022-07-13
下一篇:
eclipse+cygwin+cdt搭建c/c++开发环境发布时间:2022-07-13
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap