原文在
這里Backtrace中,一般都只有一些地址。但是利用addr2line這個工具,就可以找到對應的代碼行。前提條件是可執行程序或者動態鏈接庫編譯的時候帶-g選項。
具體來說,分兩種情況:
- 如果關注的一行backtrace位于一個可執行文件中,那么直接addr2line -e <executable> <address>
- 如果關注的backtrace位于一個動態鏈接庫中,那么麻煩一些,因為動態鏈接庫的基地址不是固定的。這個時候,首先要把進程的memory map找來。在Linux下,進程的memory map可以在/proc/<pid>/maps文件中得到。然后在這個文件中找到動態鏈接庫的基地址,然后將backtrace中的地址 - 動態鏈接庫的基地址,得到偏移地址offset address, 最后addr2line -e <shared library> <offset address>。
當然,用GDB也可以找出地址對應的代碼行。不過相比addr2line,GDB需要將BUG現象重現一遍,所以對于不好重現的BUG,或是隨機重 現的BUG來說,使用addr2line就可以直接從backtrace找到對應的代碼行,不需要重現現象,比GDB使用起來更簡單。