android API使用追踪

原创 2012年03月24日 21:52:32

使用场景

有时候,我们知道某个具体的Java API被使用到。我们想知道该API是在哪里被使用到的。


直观的方法,就是搜索源代码,找到所有使用的地方,做标记(比如打log)。然后在输出log中查看标记就知道改API在什么地方调用到了。 该方法的缺点是显而易见的:

1. 如果调用该方法的地方很多,需要修改很多处

2. 如果再想看调用该方法的方法是在哪里被使用的,需要更多的修改。简直是噩梦。


更好的办法是利用java.lang.Throwable的特性,它记录方法的调用栈,我们可以用它来显示该方法的调用,并显示整个调用的序列。具体的方法,就是在改API的实现里生成一个Throwable对象,然后跑出来就可以啦:

public int xxx (xxx) {
    Throwable obj = new Throwable ("xxx checker");
    throw obj;
    ...
}
这样子当该方法被调用到后会终止执行,被抛出异常。我们从log里看到改方法完整的调用栈。

如果不想终止程序,只需要不活该异常,并打印出来就可以了:

public int xxx (xxx) {
try {
    Throwable obj = new Throwable ("xxx checker");
    throw obj;
catche (Throwable e) {
    Log.e(TAG, "xx call trace" + e.printTrace());
}
    ...
}

但是如果我们关心的API是个本地方法(native method),该方法就不能使用了。因为本地方法是没有java实现体的。解决的方法是找到JNI实现,在JNI实现里跑出异常,从而获得调用轨迹。 比如我们想知道

TBD


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Android api使用说明

  • 2015-11-16 14:01
  • 24.44MB
  • 下载

23、Android之使用 Google API 的 GTalk

使用 Google  API 的 GTalk     关键技能  &  概念 ●  执行一个 Google  API 包装 ●  为 Google 存取配置 XMPP 开发环境设置 ●  执行....

Android Map Api 使用和开发(3)浮动搜索框 ,通过地址名称获取经纬度和详细地址并定位

这篇把  浮动搜索框 ,通过地址名称获取经纬度和详细地址并定位 这些功能加上,算是一个比较完整的地图了。 前辈们都说不要重复的造相同的轮子, 希望这整个例子对正在研究或做地图的同学有帮助。  先上图,...

[008] 百度地图API之ItemizedOverlay的使用(Android)

本篇文章主要介绍如何在百度地图上添加Overlay(即图层或覆盖物)。 Overlay简介       Overlay通常被译为“图层”或“覆盖物”。那么对于地图而言,什么称之为覆盖物?“所有...
  • hh337
  • hh337
  • 2015-06-01 22:44
  • 363

Android Map API使用文档

  • 2012-12-05 22:09
  • 768KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)