linux:如何查看函數(shù)被哪些函數(shù)調(diào)用過(guò)?
一、問(wèn)題
有個(gè)打印log的函數(shù),想知道該函數(shù)執(zhí)行的時(shí)候,之前執(zhí)行了哪些函數(shù)?
二、分析
在應(yīng)用程序打印函數(shù)棧需要通過(guò)函數(shù)backtrace(),該函數(shù)對(duì)應(yīng)頭文件如下:
#include <execinfo.h>
1、三個(gè)與打印調(diào)用棧相關(guān)的函數(shù)
打印函數(shù)棧需要使用到以下3個(gè)函數(shù)
int backtrace(void** buffer, int size);
函數(shù)功能:用于獲取當(dāng)前線程的調(diào)用堆棧。參數(shù):buffer:它是一個(gè)指針數(shù)組,函數(shù)獲取的當(dāng)前線程的調(diào)用堆棧將會(huì)被存放在buffer中。在buffer中的指針實(shí)際是從堆棧中獲取的返回地址,每一個(gè)堆棧 框架有一個(gè)返回地址。size:用來(lái)指定buffer中可以保存多少個(gè)void*元素。返回值:實(shí)際獲取的指針個(gè)數(shù),最大不超過(guò)size大小。
char** backtrace_symbols (void *const *buffer, int size);
函數(shù)功能:將從backtrace函數(shù)獲取的信息轉(zhuǎn)化為一個(gè)字符串?dāng)?shù)組。參數(shù):buffer:從backtrace函數(shù)獲取的數(shù)組指針。size:是該數(shù)組中的元素個(gè)數(shù)(backtrace函數(shù)的返回值)。返回值:是一個(gè)指向字符串?dāng)?shù)組的指針,它的大小同buffer相同。每個(gè)字符串包含了一個(gè)相對(duì)于buffer中對(duì)應(yīng)元素的 可打印信息。它包括函數(shù)名,函數(shù)的偏移地址,和實(shí)際的返回地址。
注:
1、只有使用ELF二進(jìn)制格式的程序才能獲取函數(shù)名稱(chēng)和偏移地址。在其他系統(tǒng),只有16進(jìn)制的返回地址能被獲取。另外,需要傳遞相應(yīng)的標(biāo)志給鏈接器,以能支持函數(shù)名功能即編譯選項(xiàng)-rdynamic。2、backtrace_symbols生成的字符串都是malloc出來(lái)的,最后需要free該塊內(nèi)存。void backtrace_symbols_fd (void *const *buffer, int size, int fd)
功能:backtrace_symbols_fd與backtrace_symbols函數(shù)具有相同的功能,不同的是它不會(huì)給調(diào)用者返回字符串?dāng)?shù)組,而是將結(jié)果寫(xiě)入文件描述符為fd的文件中,每個(gè)函數(shù)對(duì)應(yīng)一行.它不需要調(diào)用malloc函數(shù),因此適用于有可能調(diào)用該函數(shù)會(huì)失敗的情況。參數(shù):fd:通常填寫(xiě)STDOUT_FILENO
2. 鏈接庫(kù)
在編譯的時(shí)候需要加上**-rdynamic**選項(xiàng)。
-rdynamic
Pass the flag -export-dynamic to the ELF linker, on targets that support it. This instructs the linker to add all symbols, not only used ones, to the dynamic symbol table. This option is needed for some uses of "dlopen" or to allow obtaining backtraces from within a program.
該選項(xiàng)讓鏈接器將所有符號(hào)添加到動(dòng)態(tài)符號(hào)表中,這樣才能將函數(shù)地址翻譯成函數(shù)名,否則打印的結(jié)果是不會(huì)打印函數(shù)名的。
另外,這個(gè)選項(xiàng)不會(huì)處理static函數(shù),所以,static函數(shù)的符號(hào)無(wú)法得到。
3. 舉例 #include <execinfo.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
void fun1();
void fun2();
void fun3();
void print_stacktrace();
void print_stacktrace()
{
int size = 16;
void * array[100];
int stack_num = backtrace(array, size);
char ** stacktrace = backtrace_symbols(array, stack_num);
backtrace_symbols_fd(array,size,STDOUT_FILENO);

發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
最新活動(dòng)更多
-
6月20日立即下載>> 【白皮書(shū)】精準(zhǔn)測(cè)量 安全高效——福祿克光伏行業(yè)解決方案
-
7月3日立即報(bào)名>> 【在線會(huì)議】英飛凌新一代智能照明方案賦能綠色建筑與工業(yè)互聯(lián)
-
7月22-29日立即報(bào)名>> 【線下論壇】第三屆安富利汽車(chē)生態(tài)圈峰會(huì)
-
7.30-8.1火熱報(bào)名中>> 全數(shù)會(huì)2025(第六屆)機(jī)器人及智能工廠展
-
7月31日免費(fèi)預(yù)約>> OFweek 2025具身機(jī)器人動(dòng)力電池技術(shù)應(yīng)用大會(huì)
-
免費(fèi)參會(huì)立即報(bào)名>> 7月30日- 8月1日 2025全數(shù)會(huì)工業(yè)芯片與傳感儀表展
推薦專(zhuān)題
- 1 AI 眼鏡讓百萬(wàn) APP「集體失業(yè)」?
- 2 大廠紛紛入局,百度、阿里、字節(jié)搶奪Agent話語(yǔ)權(quán)
- 3 深度報(bào)告|中國(guó)AI產(chǎn)業(yè)正在崛起成全球力量,市場(chǎng)潛力和關(guān)鍵挑戰(zhàn)有哪些?
- 4 上海跑出80億超級(jí)獨(dú)角獸:獲上市公司戰(zhàn)投,干人形機(jī)器人
- 5 國(guó)家數(shù)據(jù)局局長(zhǎng)劉烈宏調(diào)研格創(chuàng)東智
- 6 下一代入口之戰(zhàn):大廠為何紛紛押注智能體?
- 7 百億AI芯片訂單,瘋狂傾銷(xiāo)中東?
- 8 Robotaxi新消息密集釋放,量產(chǎn)元年誰(shuí)在領(lǐng)跑?
- 9 格斗大賽出圈!人形機(jī)器人致命短板曝光:頭腦過(guò)于簡(jiǎn)單
- 10 “搶灘”家用機(jī)器人領(lǐng)域,聯(lián)通、海爾、美的等紛紛入局