android 打印调用栈

2023-05-16

转载自:https://blog.csdn.net/u010116586/article/details/91486568

java 打印调用栈:

import android.util.Log;

Log.i(TAG, Log.getStackTraceString(new Throwable()));

c++,比如netd里

Android为方便Native层打印函数的调用堆栈,专门在system/core/libutils下设计了CallStack.cpp类
如果需要打印Native的stack只需要在自己的代码的mk文件中添加对libutils.so添加依赖,在类文件中include <utils/CallStack.h> 头文件。

实现方法如下:

.cpp文件
#include <utils/CallStack.h>

CallStack stack("powered by gaojian");
 

在编译文件添加对libutils.so的依赖,如下:

Android.mk
LOCAL_SHARED_LIBRARIES += libutils
 

该方案的缺点:

  1. 需要修改编译文件,有时候依赖libutils会不成功
  2. 只能在cpp文件中使用,无法在.c文件中使用

为解决该问题,本人百度、google研究了个遍,各种攻略都以失败告终,自己也相当郁闷,
难道就没有一个简单通用方法在c/c++文件中打印堆栈吗?
答案是肯定的

自己去研究了下CallStack .cpp,突发灵感,只要稍微对CallStack .cpp做修改,即可搞定这个问题!!!!

上代码:

修改system/core/libutils/CallStack.cpp代码

diff --git a/libutils/CallStack.cpp b/libutils/CallStack.cpp
old mode 100644
new mode 100755
index bd6015e..56bcf60
--- a/libutils/CallStack.cpp
+++ b/libutils/CallStack.cpp
@@ -26,6 +26,14 @@
 
 #include <backtrace/Backtrace.h>
 
+extern "C" {
+void call_stack_fun(const char* value){
+    char buf[100];
+    memset(buf, 0, sizeof(buf));
+    snprintf(buf, sizeof(buf),"SGJ_%s",value);
+    android::CallStack mCallStack(buf);
+}
+}
 namespace android {
 
 CallStack::CallStack() {

编译出libutils.so,重命名为libutilscallstack.so(当然也可以不重命名,主要是怕和原so冲突)

然后在想打印trace的C或者C++方法中通过 dlopendlsym方法去调用该方法,代码如下

--- a/services/camera/libcameraservice/CameraService.cpp
+++ b/services/camera/libcameraservice/CameraService.cpp
@@ -64,6 +64,8 @@
 #include "api2/CameraDeviceClient.h"
 #include "utils/CameraTraces.h"

//++ begin
#include <dlfcn.h>
//++ end
 namespace {
     const char* kPermissionServiceName = "permission";
 }; // namespace anonymous
@@ -181,6 +183,14 @@ void CameraService::onFirstRef()
 {
     ALOGI("CameraService process starting");
//++ begin 
    void * prt_stack_lib = dlopen("/system/lib/libutilscallstack.so",RTLD_LAZY);
    ALOGE("SGJ dlopen %s:",dlerror());    //有问题时用这个dlerror看下错误信息
    void(*prt_stack_fun)(const char*) = (void (*)(const char *))dlsym(prt_stack_lib,"call_stack_fun");
    if (prt_stack_fun!=NULL) {
        prt_stack_fun("onFirstRef");
    }
    dlclose(prt_stack_lib);
//++ end


     BnCameraService::onFirstRef();
 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

android 打印调用栈 的相关文章

  • 未捕获的 ReferenceError: myFunction 未在 null:1 处定义 Web 视图中的 Android 异常

    我正在从活动中调用 javascript 函数 但我得到了Uncaught ReferenceError myFunction is not defined at null 1错误 这是我的文件 MainActivity java pack
  • 使用 gradle-retrolambda 和 Lightweight-Stream-API 过滤 Android 中的对象列表

    我正在尝试在我的 Android 应用程序中过滤 Java 中的对象列表 为此我遵循这个答案 https stackoverflow com a 13140130 3546389 Java 8建议 但由于Android SDK不支持Lamb
  • 使用 android 将图像上传到 Flickr

    我需要将 Flickr 与 android 集成 我已完成身份验证 我需要将图像上传到 flickr 但我不知道如何执行相同操作 我参考文件 http www flickr com services api upload api html
  • Context.startForegroundService 然后没有调用Service.startForeground

    这是我的 BroadcastReciever 类 该类处理启动电话状态 Code public class BroadCastRecieverBoot extends BroadcastReceiver Override public vo
  • Android Studio 模拟器无法加载 Windows 10

    我在 Windows 10 上全新安装了 android studio 其中包含 android api 22 的所有软件包 当我运行模拟器时 我收到以下消息 C Users admin AppData Local Android sdk
  • openFileOutput 在单例类中无法正常工作 - 想法/解决方法?

    作为一名 Android 开发新手 我遇到了一些奇怪的问题 我想创建一个类 它方法其他类 活动 任何可以用于以某种特殊方式处理文件的类 假设为了简单起见 我们将记录一些内容 如果我在活动中执行以下操作 例如在 OnClick 侦听器中 则一
  • 如何以编程方式关闭画中画

    我在使用画中画模式时遇到了这个问题 当从 PIP 本身以外的其他位置再次打开 Activity 时 我想关闭 PIP 画中画 不是来自关闭按钮 我想要与 youtube 相同的场景 即当用户单击 PIP 画中画 时 它会打开相同的活动 但是
  • Horizo​​ntalScrollView 将 GridView 缩小为小行

    当我将 Horizo ntalScrollView 放在 GridView 周围时 GridView 会被压缩到左侧的一个小列中 Gridview 的垂直滚动条甚至出现在左侧 Horizo ntalScrollView 的宽度设置为 fil
  • 在 Unity 中构建 apk 应用程序时包含文件

    在unity中构建apk文件时如何将文件和文件夹添加到apk文件中 我需要的是在Android上安装应用程序后 在应用程序的父目录 android data com company product files 中存在一些文件和文件夹 这是我
  • 如何在我的谷歌上嵌入转弯导航

    我想在我的 Android 应用程序中嵌入逐段导航 请给我一个教程或如何执行此操作的想法 提前致谢 如果您不固定使用谷歌地图 您可以使用基于 OpenStreetMap 地图的维基百科版本 的 SDK 有几个不错的 SDK 提供商 skob
  • 标签栏随键盘一起上升

    这个问题之前已经发过 但是没有答案 Problem TabBar gt 2 个选项卡 选项卡一有一个Scrollview and an EddiText 标签二 其他 贴带时EditText 软键盘上升 TabBar与它一起 一个丑陋的解决
  • 如何解决Android错误类型3?

    下面是我在项目中使用的清单格式 但是每当我尝试运行模拟器时 我都会收到下面提到的错误 请给我一个解决该错误的准确解决方案 工具信息 Android studio Nexus S API 22 android 5 1 1 我的清单文件格式
  • java.exe 以非零退出值 1 结束

    只是为了开始 我并不是真正尝试从 Android 中的 xlsx 文件中读取单元格 我已经尝试了几乎所有我在 Google 上搜索到的内容 但是每次 在两台不同的 PC 上 都是 Java 1 7 0 79 当我尝试构建 运行 这个应用程序
  • 在异步请求中使用超时回调

    我之前问过这个问题 但我将用提出的解决方案来完成这个问题 并提出另一个问题 我正在使用这个类来进行异步网络请求 http msdn microsoft com en us library system net webrequest aspx
  • Meteor:即使设置了 ANDROID_HOME 也未设置

    操作系统 Ubuntu 14 04 框架 流星1 1 0 2 应用名称 Songofy 这是输出meteor install sdk android meteor install sdk android Found Android bund
  • 通知管理器所需的权限

    我正在尝试使用以下命令将振铃器设置为静音且请勿打扰优先级 AudioManager myAudioMgr AudioManager context getSystemService Context AUDIO SERVICE Notific
  • 谷歌地图URL中参数的含义是什么

    我正在 Android 上使用 Webkit 浏览器 我想在以下 URL 中获得一个红色 A 符号
  • 使用Gradle组装时如何更改Android应用程序包名称?

    是否可以使用 Gradle 更改 Android 应用程序的包名称 我需要编译同一应用程序的两个副本 并具有唯一的包名称 这样我就可以向市场发布两次 作为使用的更简单的替代方案产品口味 正如伊森的回答 https stackoverflow
  • 调用外部应用程序

    如何从我的应用程序调用外部应用程序 例如 我需要打电话Shazam 应用程序 来自我的应用程序 我可以在应用程序的包名称中看到logcat 这对任何目的都有用吗 特别是对于 Shazam 以下代码有效 Intent intent new I
  • Android 可扩展列表视图随机播放子项

    你好 我正在使用 Android Expandable listview 并用不同的视图在其中膨胀子视图 我遇到的问题是 当我展开视图然后打开另一个父视图时 布局中的子视图会变得混乱并在代码中膨胀错误的布局 这是我的两个项目的示例代码 这是

随机推荐