python通過ctypes調用C/C++ SDK,當SDK異常時,同時打印C/C++/Python的棧信息

python通過ctypes調用C/C++ SDK,當SDK異常時,同時打印C/C++/Python的棧信息

  • 一.復現步驟
  • 二.輸出

本文演示了python通過ctypes調用C/C++ SDK,當SDK異常時,同時打印C/C++/Python的棧信息.基于traceback、addr2line、PyErr_SetString、backtrace_symbols

一.復現步驟

cat > print_backtrace.h <<-'EOF'
#ifndef __PRINT_BACKTRACE_H__
#define __PRINT_BACKTRACE_H__
#ifdef __cplusplus
extern "C" {
#endif
void print_backtrace();
#ifdef __cplusplus
}
#endif
#endif // __PRINT_BACKTRACE_H__
EOFcat > print_backtrace.cpp <<-'EOF'
#include "print_backtrace.h"
#include <stdio.h>
#include <execinfo.h>
#include <stdlib.h>
#include <string.h>
#include <stdbool.h>
#include <assert.h>
#include <stdexcept>
#include <Python.h>#define MAX_FRAMES   128
#define BUFFER_SIZE  512void print_backtrace()
{// 1.打印調用棧void *buff[MAX_FRAMES] = { 0 };unsigned int depth = backtrace(buff, MAX_FRAMES);char **strings = backtrace_symbols(buff, depth);printf("-----------------------print_backtrace(c/c++)--------------------\n");for (int i = 0; i < MAX_FRAMES; i++){if (i >= depth) {break;}// 1.1 將地址轉換為代碼路徑和行號{char cmdline[BUFFER_SIZE] = {0};snprintf(cmdline, BUFFER_SIZE, "bash ./parser.sh \"%s\"", strings[i]);FILE *pFd = popen(cmdline, "r");if ( pFd == nullptr ){printf("popen failed\n");return ;}char buf[BUFFER_SIZE] = {0};fread(buf, sizeof(buf)/sizeof (buf[0]), 1, pFd);printf("%s", buf);pclose(pFd); }        }free(strings);// 2.觸發python異常if (!Py_IsInitialized()) {Py_Initialize();}        PyGILState_STATE gstate;gstate = PyGILState_Ensure();PyErr_SetString(PyExc_RuntimeError, "print_backtrace trigger_error");PyGILState_Release(gstate);
}
EOFcat > api.c <<-'EOF'
#include <stdio.h>
#include <stdlib.h>
#include "print_backtrace.h"int function_a() {printf("%s %d\n",__FILE__,__LINE__);print_backtrace();return 0;
}int function_b() {printf("%s %d\n",__FILE__,__LINE__);function_a();return 0;
}int function_c() {printf("%s %d\n",__FILE__,__LINE__);function_b();return 0;
}int function_d() {printf("%s %d\n",__FILE__,__LINE__);function_c();return 0;
}int function_e() {printf("%s %d\n",__FILE__,__LINE__);function_d();return 0;
}
EOFcat > parser.sh <<-'EOF'
#!/bin/bashline=`echo $1 | awk '{print $1}' | sed 's/[()]/ /g'`
so_path=`echo $line | awk '{print $1}'`if [ ! -f $so_path ];thenexit 0
fiaddr_path=`echo $line | awk '{print $2}'`
function_name=`echo $addr_path | awk -F+ '{print $1}'`
offset=`echo $addr_path | awk -F+ '{print $2}'`if [ $function_name ];thenfunction_base=`nm $so_path | grep -w "$function_name" | awk '{print $1}'`abs_addr=`echo "$function_base $offset" | gawk --non-decimal-data '{A="0x"$1;B=$2;printf "0x%x\n",A+B}'`debug_info=`addr2line -f $abs_addr -e $so_path`
elsedebug_info=`addr2line -f $offset -e $so_path`
fiecho $debug_info
EOFcat > main.py <<-'EOF'
import ctypes
import tracebackdef function_a():print("function_a")lib = ctypes.CDLL('./libapi.so')function_e = lib.function_efunction_e()def function_b():print("function_b")function_a()def function_c():print("function_c")function_b()def function_d():print("function_d")function_c()try:function_d()
except:print("-----------------------print_backtrace(python)--------------------")traceback.print_exc()
EOFg++ -fPIC -g -shared -o libprint_backtrace.so print_backtrace.cpp \-I /home/anaconda3/envs/demo/include/python3.10 \/home/anaconda3/envs/demo/lib/libpython3.10.so \-Wl,-rpath=/home/anaconda3/envs/demo/lib/gcc -fPIC -g -shared -o libapi.so api.c  -L . -lprint_backtrace -Wl,-rpath=.
python3 main.py

二.輸出

function_d
function_c
function_b
function_a
api.c 30
api.c 24
api.c 18
api.c 12
api.c 6
-----------------------print_backtrace(c/c++)--------------------
print_backtrace /home/print_backtrace.cpp:18
function_a /home/api.c:8
function_b /home/api.c:14
function_c /home/api.c:20
function_d /home/api.c:26
function_e /home/api.c:32
ffi_call_unix64 :?
ffi_call_int ffi64.c:?
ffi_call ??:?
addr2line: DWARF error: can't find .debug_ranges section.
_ctypes_callproc.cold :?
addr2line: DWARF error: can't find .debug_ranges section.
PyCFuncPtr_call.cold :?
nm: /lib/x86_64-linux-gnu/libc.so.6: no symbols
?? ??:0
-----------------------print_backtrace(python)--------------------
RuntimeError: print_backtrace trigger_errorThe above exception was the direct cause of the following exception:Traceback (most recent call last):File "/home/main.py", line 39, in <module>function_d()File "/home/main.py", line 36, in function_dfunction_c()File "/home/main.py", line 32, in function_cfunction_b()File "/home/main.py", line 28, in function_bfunction_a()File "/home/main.py", line 24, in function_afunction_e()
SystemError: <_FuncPtr object at 0x7f10c6d4cdc0> returned a result with an exception set

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/12418.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/12418.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/12418.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

自媒體的發展趨勢:從個人表達到全球話語權

一、引言隨著數字技術的快速發展&#xff0c;信息傳播的方式和格局也在不斷變化。自媒體&#xff0c;作為其中的一股重要力量&#xff0c;正在以它的獨特方式改變著全球的信息傳播和社會發展。本文將從自媒體的定義及發展歷程入手&#xff0c;深入探討自媒體未來的發展趨勢&…

感知局部規劃--似然場局部規劃

系列文章目錄 提示&#xff1a;這里可以添加系列文章的所有文章的目錄&#xff0c;目錄需要自己手動添加 TODO:寫完再整理 文章目錄 系列文章目錄前言感知導航感知似然場局部規劃&#xff08;很像DWA但是不依賴地圖&#xff0c;完全依賴感知&#xff09; 前言 認知有限&#x…

Uniapp開發入門:構建跨平臺應用的全面指南

引言 什么是Uniapp Uniapp是一款由DCloud公司推出的基于Vue.js的跨平臺應用開發框架。它的核心理念是“一套代碼&#xff0c;多端運行”&#xff0c;開發者只需編寫一份代碼&#xff0c;即可生成包括iOS、Android、H5、微信小程序、支付寶小程序、百度小程序等多平臺的應用。…

初識C++ · string的使用(2)

目錄 1 Modifiers部分 1.1 assign的使用 1.2 insert的使用 1.3 erase的使用 1.4 replace的使用 2 capacity部分 2.1 max_size的使用 2.2 capacity的使用 2.3 reserve的使用 2.4 shrink_to_fit簡介 2.5 resize的使用 2.6 clear的使用 3 String operations部分 3.1 …

[數據結構1.0]快速排序

最近學習了快速排序&#xff0c;鼠鼠俺來做筆記了&#xff01; 本篇博客用排升序為例介紹快速排序&#xff01; 1.快速排序 快速排序是Hoare于1962年提出的一種二叉樹結構的交換排序方法&#xff0c;其基本思想為&#xff1a;任取待排序元素序列中的某元素作為基準值&#x…

202103青少年軟件編程(Python)等級考試試卷(一級)

一、單選題&#xff08;共25題&#xff0c;每題2分&#xff0c;共50分&#xff09; 下列哪個操作不能退出IDLE環境&#xff1f;&#xff08; &#xff09; A、AltF4 B、CtrlQ C、按ESC鍵 D、exit() 試題編號&#xff1a;20210124-yfj-003 題型&#xff1a;單選題 答案&#xf…

Java面試八股之一個char類型變量能不能存儲一個中文字符

Java中一個char類型變量能不能存儲一個中文字符&#xff1f;為什么&#xff1f; Java中一個char類型變量可以存儲一個中文字符。原因如下&#xff1a; Unicode編碼支持&#xff1a;Java語言采用Unicode字符集作為其內建字符編碼方式。Unicode是一種廣泛接受的字符編碼標準&am…

兩小時看完花書(深度學習入門篇)

1.深度學習花書前言 機器學習早期的時候十分依賴于已有的知識庫和人為的邏輯規則&#xff0c;需要人們花大量的時間去制定合理的邏輯判定&#xff0c;可以說是有多少人工&#xff0c;就有多少智能。后來逐漸發展出一些簡單的機器學習方法例如logistic regression、naive bayes等…

mybatisplus查詢練習代碼

mybatisplus查詢練習代碼 package com.yase;import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.yase.entity.Student; import com.yase.entity.Teacher; import com.yase…

什么是CCRC?做什么用的?

CCRC&#xff08;中國網絡安全審查認證和市場監管大數據中心&#xff09;原名為中國網絡安全審查技術與認證中心&#xff0c;也被稱為中國信息安全認證中心&#xff08;ISCCC&#xff09;。 該中心是經中央機構編制委員會辦公室批準成立的&#xff0c;其主要職責是依據國家法律…

kafka集群傳統部署(raft模式)—— 筑夢之路

kafka二進制包&#xff1a;https://dlcdn.apache.org/kafka/3.7.0/kafka_2.13-3.7.0.tgz 集群規劃 主機名IP地址節點ID角色分配kafka1192.168.100.1001broker,controllerkafka2192.168.100.1012broker,controllerkafka3192.168.100.1023broker,controller 編輯配置文件 con…

代碼隨想錄算法訓練營第36天|● 738.單調遞增的數字 ● 968.監控二叉樹

738. 單調遞增的數字 發現第一位變小了其他的迅速變9 class Solution:def monotoneIncreasingDigits(self, n: int) -> int:strnlist(str(n))for i in range(len(strn)-1,0,-1):if strn[i-1]>strn[i]:strn[i-1]str(int(strn[i-1])-1)for j in range(i,len(strn)):strn[…

超級簡單的地圖操作工具開發可疑應急,地圖畫點,畫線,畫區域,獲取地圖經緯度等

使用echars的地圖畫點,畫線,畫區域,獲取地圖經緯度等 解壓密碼:10086007 地圖也是用臨時的bmap.js和china.js純離線二選一 一共就這么多文件 畫點,畫線,畫區域 點擊地圖獲取經緯度-打印到控制臺,這樣就能渲染航跡,多變形,結合其他算法算圓等等操作 下載資源:https://download…

JSON-server 服務的搭建

1、全局安裝&#xff1a; pnpm i -g json-server2、創建db.json文件 {"posts": [{"id": 1,"title": "json-server","author": "typicode"}],"comments":[{"id": 1,"body": "…

什么情況下會造成索引失效?

2.3.4. 索引失效 對索引使用左或者左右模糊匹配 使用左或者左右模糊匹配的時候&#xff0c;也就是 like %xx 或者 like %xx% 這兩種方式都會造成索引失效。但是如果前綴是確定的那么就可以使用到索引&#xff0c;例如 name like 許%。 因為索引 B 樹是按照「索引值」有序排列…

SpringBoot 中 zip 文件解壓工具類

SpringBoot 中 zip 文件解壓工具類 zip 文件解壓&#xff08;不支持密碼&#xff09; 相關 Maven 依賴 <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.6</version>…

練習題(2024/5/14)

1四數相加 II 給你四個整數數組 nums1、nums2、nums3 和 nums4 &#xff0c;數組長度都是 n &#xff0c;請你計算有多少個元組 (i, j, k, l) 能滿足&#xff1a; 0 < i, j, k, l < nnums1[i] nums2[j] nums3[k] nums4[l] 0 示例 1&#xff1a; 輸入&#xff1a;n…

代碼隨想錄訓練營Day28:貪心算法06

1.738單調遞增的數字 貪心策略&#xff1a;如果strNum[i]<strNum[i-1]那么strNum[i] 9,strNum[i-1]--;//比如87對應的最大的單調遞增的就是79. 具體實現&#xff1a; 對于遇到小于的情況&#xff1a;如果strNum[i]<strNum[i-1]那么strNum[i] 9,strNum[i-1]--;遍歷順…

linux phpstudy 重啟命令

[rootLinuxWeb phpstudy]# ./system/phpstudyctl restart 查看命令 1) phpstudy -start 啟動小皮面板 2) phpstudy -stop 停止小皮面板 3) phpstudy -restart 重啟小皮面板 4) phpstudy -status 查詢面板狀態 5) phpstudy -in…

OFDM802.11a的FPGA實現(十五)短訓練序列:STS(含Matlab和verilog代碼)

原文鏈接&#xff08;相關文章合集&#xff09;&#xff1a;OFDM 802.11a的xilinx FPGA實現 1.前言 在之前已經完成了data域數據的處理&#xff0c;在構建整個802.11a OFDM數據幀的時候&#xff0c;還剩下前導碼和signal域的數據幀&#xff0c;這兩部分的內容。 PLCP的前導部分…