android C++ 添加调用栈 方便调试

本文详细介绍如何在Android应用中使用C++打印堆栈跟踪,包括`CallStack`的使用方法,以及如何通过`addr2line`工具定位`libmediaplayerservice.so`的调用位置。此外,还介绍了列表、表格、代码片段、注释、数学公式和甘特图等技术元素的创建方法。

一、c++打印堆栈

1、Android.pb的shared_libs中增加
“libutils”,
“libutilscallstack”,

=>一定要加这两个lib,不然打不出堆栈。

2、#include <utils/CallStack.h>
CallStack::logStack(“AudioTrackaaaccc”);

3、打印堆栈如下:
05-20 14:26:55.090 2120 8329 D AudioTrackaaaccc: #00 pc 0003d81b /system/lib/libaudioclient.so (android::AudioTrack::set(audio_stream_type_t, unsigned int, audio_format_t, unsigned int, unsigned int, audio_output_flags_t, void ()(int, void, void*), void*, int, android::spandroid::IMemory const&, bool, audio_session_t, android::AudioTrack::transfer_type, audio_offload_info_t const*, unsigned int, int, audio_attributes_t const*, bool, float, int)+150)
05-20 14:26:55.090 2120 8329 D AudioTrackaaaccc: #01 pc 0003d747 /system/lib/libaudioclient.so (android::AudioTrack::AudioTrack(audio_stream_type_t, unsigned int, audio_format_t, unsigned int, unsigned int, audio_output_flags_t, void ()(int, void, void*), void*, int, audio_session_t, android::AudioTrack::transfer_type, audio_offload_info_t const*, unsigned int, int, audio_attributes_t const*, bool, float, int)+342)
05-20 14:26:55.090 2120 8329 D AudioTrackaaaccc: #02 pc 0004e725 /system/lib/libmediaplayerservice.so (android::MediaPlayerService::AudioOutput::open(unsigned int, int, unsigned int, audio_format_t, int, unsigned int ()(android::MediaPlayerBase::AudioSink, void*, unsigned int, void*, android::MediaPlayerBase::AudioSink::cb_event_t), void*, audio_output_flags_t, audio_offload_info_t const*, bool, unsigned int)+772)
05-20 14:26:55.090 2120 8329 D AudioTrackaaaccc: #03 pc 00006a38 /system/lib/libaw_output.so (__SdStart(SoundCtrl*)+2156)
05-20 14:26:55.090 2120 8329 D AudioTrackaaaccc: #04 pc 0000d874 /system/lib/libcdx_playback.so (handleStart+304)
05-20 14:26:55.090 2120 8329 D AudioTrackaaaccc: #05 pc 0000ec70 /system/lib/libcdx_playback.so (AudioRenderThread+176)
05-20 14:26:55.090 2120 8329 D AudioTrackaaaccc: #06 pc 000a6177 /apex/com.android.runtime/lib/bionic/libc.so (__pthread_start(void*)+20)
05-20 14:26:55.090 2120 8329 D AudioTrackaaaccc: #07 pc 000601b1 /apex/com.android.runtime/lib/bionic/libc.so (__start_thread+30)

假如我要看libmediaplayerservice.so的调用地方,用add2line工具。如:
xy@ubuntu-204:~/android/T5-v0.6/android$ ./prebuilts/gcc/linux-x86/arm/arm-linux-androideabi-4.9/bin/arm-linux-androideabi-addr2line -e out/target/product/haiwai3/symbols/system/lib/libmediaplayerservice.so 0004e725
frameworks/av/media/libmediaplayerservice/MediaPlayerService.cpp:2203

也就是addr2line 工具
arm-linux-androideabi-addr2line -e libmediaplayerservice.so 0004e725
一定要用:symbols/system/lib/libmediaplayerservice.so这个symbols的库

链接: link.

图片: Alt

带尺寸的图片: Alt

居中的图片: Alt

居中并且带尺寸的图片: Alt

当然,我们为了让用户更加便捷,我们增加了图片拖拽功能。

如何插入一段漂亮的代码片

博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片.

// An highlighted block
var foo = 'bar';

生成一个适合你的列表

  • 项目
    • 项目
      • 项目
  1. 项目1
  2. 项目2
  3. 项目3
  • 计划任务
  • 完成任务

创建一个表格

一个简单的表格是这么创建的:

项目Value
电脑$1600
手机$12
导管$1

设定内容居中、居左、居右

使用:---------:居中
使用:----------居左
使用----------:居右

第一列第二列第三列
第一列文本居中第二列文本居右第三列文本居左

SmartyPants

SmartyPants将ASCII标点字符转换为“智能”印刷标点HTML实体。例如:

TYPEASCIIHTML
Single backticks'Isn't this fun?'‘Isn’t this fun?’
Quotes"Isn't this fun?"“Isn’t this fun?”
Dashes-- is en-dash, --- is em-dash– is en-dash, — is em-dash

创建一个自定义列表

Markdown
Text-to- HTML conversion tool
Authors
John
Luke

如何创建一个注脚

一个具有注脚的文本。1

注释也是必不可少的

Markdown将文本转换为 HTML

KaTeX数学公式

您可以使用渲染LaTeX数学表达式 KaTeX:

Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n1)!nN 是通过欧拉积分

Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t   . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=0tz1etdt.

你可以找到更多关于的信息 LaTeX 数学表达式here.

新的甘特图功能,丰富你的文章

Mon 06 Mon 13 Mon 20 已完成 进行中 计划一 计划二 现有任务 Adding GANTT diagram functionality to mermaid
  • 关于 甘特图 语法,参考 这儿,

UML 图表

可以使用UML图表进行渲染。 Mermaid. 例如下面产生的一个序列图:

张三 李四 王五 你好!李四, 最近怎么样? 你最近怎么样,王五? 我很好,谢谢! 我很好,谢谢! 李四想了很长时间, 文字太长了 不适合放在一行. 打量着王五... 很好... 王五, 你怎么样? 张三 李四 王五

这将产生一个流程图。:

链接
长方形
圆角长方形
菱形
  • 关于 Mermaid 语法,参考 这儿,

FLowchart流程图

我们依旧会支持flowchart的流程图:

Created with Raphaël 2.3.0 开始 我的操作 确认? 结束 yes no
  • 关于 Flowchart流程图 语法,参考 这儿.

导出与导入

导出

如果你想尝试使用此编辑器, 你可以在此篇文章任意编辑。当你完成了一篇文章的写作, 在上方工具栏找到 文章导出 ,生成一个.md文件或者.html文件进行本地保存。

导入

如果你想加载一篇你写过的.md文件,在上方工具栏可以选择导入功能进行对应扩展名的文件导入,
继续你的创作。


  1. 注脚的解释 ↩︎

在处理 `libcrypto.so.1.1` 的错误“cannot enable executable stack as shared object”时,通常意味着动态链接库的堆栈被标记为可执行,这在某些系统上可能被安全策略禁止。该问题常见于运行 OpenSSL 相关库的程序,尤其是在某些 Linux 发行版或容器环境中。 ### 错误原因 - **可执行堆栈限制**:某些系统通过 `GNU_STACK` 标记强制要求共享库的堆栈不可执行,以防止潜在的安全漏洞。 - **OpenSSL 配置或编译问题**:如果 OpenSSL 编译时启用了某些特性,可能会导致生成的 `libcrypto.so.1.1` 包含可执行堆栈。 ### 解决方案 #### 1. 修改共享库的堆栈标志 可以使用 `execstack` 工具来修改 `libcrypto.so.1.1` 的堆栈标志,禁用可执行堆栈: ```bash sudo apt install execstack # 安装 execstack execstack -c /path/to/libcrypto.so.1.1 # 清除可执行堆栈标志 execstack /path/to/libcrypto.so.1.1 # 检查是否已禁用可执行堆栈 ``` 此方法适用于临时修复问题,但不推荐在生产环境中长期使用,因为它可能会影响安全性。 #### 2. 重新编译 OpenSSL 如果使用的是自定义编译的 OpenSSL,可以在编译前通过配置禁用某些特性,以避免生成包含可执行堆栈的库。例如: ```bash ./Configure linux-x86_64 --prefix=/usr/local/openssl no-asm make sudo make install ``` 此外,可以在编译时使用 `-Wl,-z,noexecstack` 链接器选项,确保生成的共享库不启用可执行堆栈: ```bash LDFLAGS="-Wl,-z,noexecstack" ./Configure linux-x86_64 --prefix=/usr/local/openssl ``` #### 3. 使用静态链接 如果动态链接导致问题,可以考虑将 `libcrypto` 静态链接到应用程序中,从而避免共享库的堆栈问题。静态链接的 OpenSSL 可以通过以下方式构建: ```bash ./Configure linux-x86_64 no-shared --prefix=/usr/local/openssl-static make sudo make install ``` 然后在应用程序的编译命令中链接静态库: ```bash gcc -o myapp myapp.c /usr/local/openssl-static/lib/libcrypto.a ``` #### 4. 更新系统或容器配置 某些 Linux 发行版(如 CentOS、Ubuntu)可以通过修改内核或 SELinux/AppArmor 配置来允许可执行堆栈,但这通常不推荐,除非确认没有其他替代方案。例如,可以使用以下命令临时允许可执行堆栈: ```bash sudo setsebool -P allow_execstack=1 # SELinux 环境 ``` ### 验证修复 在完成上述修改后,可以使用 `readelf` 检查共享库的堆栈标志: ```bash readelf -l /path/to/libcrypto.so.1.1 | grep GNU_STACK ``` 如果输出为 `GNU_STACK 0x000000 0x0000000000000000 0x0000000000000000 0x00000 0x00000 RW 0x10`,则表示堆栈不可执行,问题已解决。 ### 注意事项 - 在生产环境中,建议优先使用重新编译 OpenSSL 并禁用可执行堆栈的方式,而不是直接修改现有库。 - 如果使用的是容器环境(如 Docker),确保在构建镜像时采用静态链接或修改编译参数。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值