jdb调试问题集锦

https://bbs.kanxue.com/thread-210049.htm蓝铁

  1 2017-8-25 19:40

  4 楼 

 0

根据提示,可知,出错的地方是,android.app.ActivityThread.handleBindApplication(),  行=4,400
查看源码可以发现,代码中指向的是app.onCreate()
                        try  {
                                mInstrumentation.callApplicationOnCreate(app);//内部调用的是app.onCreate()

                        }  catch  (Exception  e)  {
                                if  (!mInstrumentation.onException(app,  e))  {
                                        throw  new  RuntimeException(
                                                "Unable  to  create  application  "  +  app.getClass().getName()
                                                +  ":  "  +  e.toString(),  e);
                                }
                        }

出现这个错误的原因是其在Java层调用了Debug.  isDebuggerConnected
native层调用的是Dalvik_dalvik_system_VMDebug_isDebuggerConnected
最底层是dvmDbgIsDebuggerConnected
函数内部是判断的gDvm.debuggerActive

解决方案就是,在jdb连接之后,在patch  dvmDbgIsDebuggerConnected函数

我正在使用 jdb dubugger,它的问题是在每个捕获的异常上停止,尽管我没有执行任何 catch .... 语句。在类加载期间,有数百个:

发生异常:java.io.FileNotFoundException (uncaught)"thread=Thread-2-EmulatorEngine", sun.misc.URLClassPath$JarLoader.ensureOpen(), line=634 bci=30

有什么方法可以指示 jdb 跳过这些异常吗?

附注。我听说过 IDE 编辑器。有理由使用jdb。

我意识到我不够小心。JDB 在启动这些行后写入

设置未捕获的 java.lang.Throwable

设置延迟未捕获的 java.lang.Throwable

所以,要禁用它,我需要输入一个命令

ignore uncaught java.lang.Throwable

jdb 调试

C:\Users\Reverse>adb shell am start -D -n lwf.lc.pncdd/lwf.lc.pncdd.MainC

查看内存情况:

cat /proc/N/maps

jdb调试目标进程

C:\Users\Reverse>adb jdwp 查看目标进程PID

C:\Users\Reverse>adb forward tcp:9999 jdwp:PID 转发

C:\Users\Reverse>jdb -connect com.sun.jdi.SocketAttach:port=9999,hostname=localhost
设置未捕获的java.lang.Throwable
设置延迟的未捕获的java.lang.Throwable

正在初始化jdb...
> exit

jdb调试实例:

jdb -connect com.sun.jdi.SocketAttach:hostname=127.0.0.1,port=8631
设置未捕获的java.lang.Throwable
设置延迟的未捕获的java.lang.Throwable
正在初始化jdb...
>
出现异常错误: java.lang.ClassNotFoundException (未捕获)"线程=Thread-2", dalvik.system.BaseDexClassLoader.findClass(), 行=201 bci=84

Thread-2[1] wherei
  [1] dalvik.system.BaseDexClassLoader.findClass (BaseDexClassLoader.java:201), pc = 84
  [2] java.lang.ClassLoader.loadClass (ClassLoader.java:379), pc = 28
  [3] java.lang.ClassLoader.loadClass (ClassLoader.java:312), pc = 1
Thread-2[1] locals
方法参数:
suppressedExceptions = instance of java.util.ArrayList(id=9327)
c = null
本地变量:
name = "com.target.os.ClassName"
cnfe = instance of java.lang.ClassNotFoundException(id=9325)
Thread-2[1]

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AppNinja

你的鼓励是我创作最大的动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值