Android中用gdb调试一启动就崩溃的程序

原文地址:http://blog.csdn.net/ariesjzj/article/details/7393573

一般情况下程序是在某一个点挂掉的,我们可以用adb shell ps查到PID,然后在target端用gdbserver attach上去,最后在host端用gdb连上去调。但程序往往不会崩溃得这么完美,很多情况下程序一起来就crash掉了。这个时候分两种情况:1.真的是一起来就挂掉的。2.一起来后稍稍过会就挂掉的。

 

这里我用的系统是:

Host: Ubuntu x64

Target: Android ICS

 

方法一:针对第一种情况。首先在target的Android中运行Dev Tools->Development Settings,点按钮"None"选择你要调的程序(这里比如是flashplayer),然后选中Wait for debugger就可以退出了。Dev Tools在大多数情况下是默认安装的,但如果你很不幸地找不到,参照http://developer.android.com/guide/developing/debugging/debugging-devtools.html把emulator里的Dev Tools搬过来。

这时候打开要调的程序就会停住:

当然,这时候wait for debugger不是wait gdb,是DDMS。但因为我们最后是用gdb调,所以这时候要趁机用gdb attach上去。具体gdb的设置和使用请参见另一博文(http://blog.csdn.net/ariesjzj/article/details/7375048)。一般步骤是先在target开gdbserver,然后在host开gdb client:

jzj@jzj-laptop:~/debug$ gdb -x init.gdb
GNU gdb (GDB) 7.1-ubuntu
Copyright (C) 2010 Free Software Foundation, Inc.
...

__futex_syscall4 () at bionic/libc/arch-x86/bionic/atomics_x86.S:73
73     popl    %esi
Created trace state variable $trace_timestamp for target's variable 1."
(gdb)

gdb启动后就可以设断点啊看变量什么的了,设好断点后输入continue继续运行,但就像前面提到的wait for debugger不是wait gdb,所以gdb说continue还不能continue。打开DDMS

有个红色虫子表示停住了,点上面绿色虫子程序就可以继续运行程序了。你也可以先打开DDMS,然后用jdb attach上去来使程序继续下去:

$jdb -attach localhost:8700

然后就可以换由gdb控制,尽情调试了。

 

方法二:针对第二种情况。用脚本启动目标程序,然后马上attach上去。脚本总比人肉输入快,所以有时候可以用这个方法拼一下看是先crash还是先attach上,优点是比较简单。下面是个简单的例子(调的是Adobe reader),注意其中的grep的字符串得看情况而定,现实当中用时可以先把PID打印出来,或者自动判断下是否唯一。

#!/bin/bash

ACTION=android.intent.action.MAIN
COM=com.adobe.reader/com.adobe.reader.AdobeReader

adb root
adb shell am start -a $ACTION -n $COM
PID=`adb shell ps | grep "reader" | awk '{print $2}'`
CMD="adb shell /data/gdbserver :1234 --attach $PID"
echo $CMD
eval $CMD

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值