热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

glog库(谷歌日志)在stacktrace中打印出`(unknown)`

如何解决《glog库(谷歌日志)在stacktrace中打印出`(unknown)`》经验,为你挑选了1个好方法。

glog库正在(unknown)堆栈跟踪中打印某些堆栈帧.

我在Ubuntu上18.04使用标准libgoogle-glog-dev包:

$ cat > t.cc
#include 
void h() { LOG(FATAL) <<"test"; }
void g() { h(); }
void f() { g(); }
int main(int argc, char** argv) {
  google::InitGoogleLogging(argv[0]);
  f();
}
^D

编译时的上述程序......

$ g++ t.cc -lglog

......然后跑......

$ ./a.out

...输出以下内容:

F1219 13:54:46.608317 13408 t.cc:3] test
*** Check failure stack trace: ***
    @     0x7f90ddd970cd  google::LogMessage::Fail()
    @     0x7f90ddd98f33  google::LogMessage::SendToLog()
    @     0x7f90ddd96c28  google::LogMessage::Flush()
    @     0x7f90ddd99999  google::LogMessageFatal::~LogMessageFatal()
    @     0x56279a0a7b30  (unknown)
    @     0x56279a0a7b45  (unknown)
    @     0x56279a0a7b51  (unknown)
    @     0x56279a0a7b77  (unknown)
    @     0x7f90dd632b97  __libc_start_main
    @     0x56279a0a79fa  (unknown)
Aborted (core dumped)

请参阅使用帧(unknown)-我希望他们阅读main,f,g,h

我试过添加-rdynamic,但我仍然观察到相同的行为:

 $ g++ t.cc -lglog -rdynamic

我试过添加-g,但我仍然观察到相同的行为:

 $ g++ t.cc -lglog -o t -g -rdynamic

Damian.. 6

我只是尝试过,它对我有用.
我可以看到h(),g(),f()的结果显示在堆栈跟踪中.

F1219 16:20:16.171772 20931 main.cpp:2] test
*** Check failure stack trace: ***
    @     0x7f951ee03e6d  (unknown)
    @     0x7f951ee05ced  (unknown)
    @     0x7f951ee03a5c  (unknown)
    @     0x7f951ee0663e  (unknown)
    @           0x40089a  h()
    @           0x4008af  g()
    @           0x4008bb  f()
    @           0x4008e1  main
    @     0x7f951e22e3d5  __libc_start_main
    @           0x4007a9  (unknown)

Process finished with exit code 134 (interrupted by signal 6: SIGABRT)

这是我的CMakeLists.txt文件

cmake_minimum_required(VERSION 3.13)
project(test_glog)

set(CMAKE_CXX_STANDARD 14)

include_directories(/usr/include)
link_libraries(glog)
add_executable(test_glog main.cpp)

当我编译时,它扩展到这个:

我在CentOS 7上并安装了以下库:

yum install glog-devel gflags-devel

以下是我如何构建它:

[user@cent1 build]$ make VERBOSE=1
/usr/bin/cmake3 -H/home/user/CLionProjects/test_glog -B/home/user/CLionProjects/test_glog/build --check-build-system CMakeFiles/Makefile.cmake 0
/usr/bin/cmake3 -E cmake_progress_start /home/user/CLionProjects/test_glog/build/CMakeFiles /home/user/CLionProjects/test_glog/build/CMakeFiles/progress.marks
make -f CMakeFiles/Makefile2 all
make[1]: Entering directory `/home/user/CLionProjects/test_glog/build'
make -f CMakeFiles/test_glog.dir/build.make CMakeFiles/test_glog.dir/depend
make[2]: Entering directory `/home/user/CLionProjects/test_glog/build'
cd /home/user/CLionProjects/test_glog/build && /usr/bin/cmake3 -E cmake_depends "Unix Makefiles" /home/user/CLionProjects/test_glog /home/user/CLionProjects/test_glog /home/user/CLionProjects/test_glog/build /home/user/CLionProjects/test_glog/build /home/user/CLionProjects/test_glog/build/CMakeFiles/test_glog.dir/DependInfo.cmake --color=
make[2]: Leaving directory `/home/user/CLionProjects/test_glog/build'
make -f CMakeFiles/test_glog.dir/build.make CMakeFiles/test_glog.dir/build
make[2]: Entering directory `/home/user/CLionProjects/test_glog/build'
[ 50%] Building CXX object CMakeFiles/test_glog.dir/main.cpp.o
/opt/rh/devtoolset-7/root/usr/bin/c++    -std=gnu++14 -o CMakeFiles/test_glog.dir/main.cpp.o -c /home/user/CLionProjects/test_glog/main.cpp
[100%] Linking CXX executable test_glog
/usr/bin/cmake3 -E cmake_link_script CMakeFiles/test_glog.dir/link.txt --verbose=1
/opt/rh/devtoolset-7/root/usr/bin/c++     CMakeFiles/test_glog.dir/main.cpp.o  -o test_glog -lglog 
make[2]: Leaving directory `/home/user/CLionProjects/test_glog/build'
[100%] Built target test_glog
make[1]: Leaving directory `/home/user/CLionProjects/test_glog/build'
/usr/bin/cmake3 -E cmake_progress_start /home/user/CLionProjects/test_glog/build/CMakeFiles 0

更新:我在vm中安装Debian ubuntu-18.04.1-desktop-amd64.iso并从源代码构建glog.您的示例现在显示:

$ ./a.out 
F0102 23:54:15.603329 10358 t.cc:2] test
*** Check failure stack trace: ***
    @     0x55c930b28d2c  google::LogMessage::Fail()
    @     0x55c930b28c74  google::LogMessage::SendToLog()
    @     0x55c930b285b5  google::LogMessage::Flush()
    @     0x55c930b2be66  google::LogMessageFatal::~LogMessageFatal()
    @     0x55c930b25820  google::thread_msg_data
    @     0x55c930b25835  google::thread_msg_data
    @     0x55c930b25841  google::thread_msg_data
    @     0x55c930b25867  google::thread_msg_data
    @     0x7ff9fbf2eb97  __libc_start_main
    @     0x55c930b256ea  google::thread_msg_data
    @              (nil)  (unknown)
Aborted (core dumped)

我可以看到我们尝试解决这个问题,所以我建议你用glog打开一个问题. https://github.com/google/glog/pull/347/commits/26459400f49850bda8e736882c6f22c2ce766761

我还尝试直接从命令链接构建它并显示设置.不确定glog库的构建设置是否会产生影响.

$ g++ t.cc -lglog --verbose
Using built-in specs.
COLLECT_GCC=g++
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/7/lto-wrapper
OFFLOAD_TARGET_NAMES=nvptx-none
OFFLOAD_TARGET_DEFAULT=1
Target: x86_64-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu 7.3.0-27ubuntu1~18.04' --with-bugurl=file:///usr/share/doc/gcc-7/README.Bugs --enable-languages=c,ada,c++,go,brig,d,fortran,objc,obj-c++ --prefix=/usr --with-gcc-major-version-only --program-suffix=-7 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-libmpx --enable-plugin --enable-default-pie --with-system-zlib --with-target-system-zlib --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64,mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu
Thread model: posix
gcc version 7.3.0 (Ubuntu 7.3.0-27ubuntu1~18.04) 
COLLECT_GCC_OPTIOnS='-v' '-shared-libgcc' '-mtune=generic' '-march=x86-64'
 /usr/lib/gcc/x86_64-linux-gnu/7/cc1plus -quiet -v -imultiarch x86_64-linux-gnu -D_GNU_SOURCE t.cc -quiet -dumpbase t.cc -mtune=generic -march=x86-64 -auxbase t -version -fstack-protector-strong -Wformat -Wformat-security -o /tmp/ccoFCYTb.s
GNU C++14 (Ubuntu 7.3.0-27ubuntu1~18.04) version 7.3.0 (x86_64-linux-gnu)
    compiled by GNU C version 7.3.0, GMP version 6.1.2, MPFR version 4.0.1, MPC version 1.1.0, isl version isl-0.19-GMP

GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
ignoring duplicate directory "/usr/include/x86_64-linux-gnu/c++/7"
ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"
ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/7/../../../../x86_64-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
 /usr/include/c++/7
 /usr/include/x86_64-linux-gnu/c++/7
 /usr/include/c++/7/backward
 /usr/lib/gcc/x86_64-linux-gnu/7/include
 /usr/local/include
 /usr/lib/gcc/x86_64-linux-gnu/7/include-fixed
 /usr/include/x86_64-linux-gnu
 /usr/include
End of search list.
GNU C++14 (Ubuntu 7.3.0-27ubuntu1~18.04) version 7.3.0 (x86_64-linux-gnu)
    compiled by GNU C version 7.3.0, GMP version 6.1.2, MPFR version 4.0.1, MPC version 1.1.0, isl version isl-0.19-GMP

GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
Compiler executable checksum: 1bfae38ae5df64de6196cbd8c3b07d86
COLLECT_GCC_OPTIOnS='-v' '-shared-libgcc' '-mtune=generic' '-march=x86-64'
 as -v --64 -o /tmp/ccvUzQBB.o /tmp/ccoFCYTb.s
GNU assembler version 2.30 (x86_64-linux-gnu) using BFD version (GNU Binutils for Ubuntu) 2.30
COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/7/:/usr/lib/gcc/x86_64-linux-gnu/7/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/7/:/usr/lib/gcc/x86_64-linux-gnu/
LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/7/:/usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/7/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/7/../../../:/lib/:/usr/lib/
COLLECT_GCC_OPTIOnS='-v' '-shared-libgcc' '-mtune=generic' '-march=x86-64'
 /usr/lib/gcc/x86_64-linux-gnu/7/collect2 -plugin /usr/lib/gcc/x86_64-linux-gnu/7/liblto_plugin.so -plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/7/lto-wrapper -plugin-opt=-fresolution=/tmp/ccNEOWk1.res -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lc -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lgcc --sysroot=/ --build-id --eh-frame-hdr -m elf_x86_64 --hash-style=gnu --as-needed -dynamic-linker /lib64/ld-linux-x86-64.so.2 -pie -z now -z relro /usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu/Scrt1.o /usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu/crti.o /usr/lib/gcc/x86_64-linux-gnu/7/crtbeginS.o -L/usr/lib/gcc/x86_64-linux-gnu/7 -L/usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu -L/usr/lib/gcc/x86_64-linux-gnu/7/../../../../lib -L/lib/x86_64-linux-gnu -L/lib/../lib -L/usr/lib/x86_64-linux-gnu -L/usr/lib/../lib -L/usr/lib/gcc/x86_64-linux-gnu/7/../../.. /tmp/ccvUzQBB.o -lglog -lstdc++ -lm -lgcc_s -lgcc -lc -lgcc_s -lgcc /usr/lib/gcc/x86_64-linux-gnu/7/crtendS.o /usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu/crtn.o
COLLECT_GCC_OPTIOnS='-v' '-shared-libgcc' '-mtune=generic' '-march=x86-64'

这是运行时的输出:

$ ./a.out 
F0106 12:07:11.753652 28547 t.cc:2] test
*** Check failure stack trace: ***
    @     0x55c500dedd2c  google::LogMessage::Fail()
    @     0x55c500dedc74  google::LogMessage::SendToLog()
    @     0x55c500ded5b5  google::LogMessage::Flush()
    @     0x55c500df0e66  google::LogMessageFatal::~LogMessageFatal()
    @     0x55c500dea820  google::thread_msg_data
    @     0x55c500dea835  google::thread_msg_data
    @     0x55c500dea841  google::thread_msg_data
    @     0x55c500dea867  google::thread_msg_data
    @     0x7f882d938b97  __libc_start_main
    @     0x55c500dea6ea  google::thread_msg_data
    @              (nil)  (unknown)
Aborted (core dumped)

更新2:glog开发人员Evgeny Prigorodov一直在研究这个问题并确定了问题.我相信这个问题很快就会解决.

所以这是在a93a451之后src/symbolize.cc中发生的事情:

堆栈跟踪中的每一行都在函数SymbolizeAndDemangle()中准备.它计算变量start_address/base_address并调用函数GetSymbolFromObjectFile(),它试图查找对应于给定帧指令指针(pc)的符号.

在v0.3.4中,对GetSymbolFromObjectFile()的调用传递了start_address的值,它是内存区域的起始地址,永远不能为零.GetSymbolFromObjectFile()没有检查start_address的值,只是将它用于两个符号表中的查找.

在v0.3.5中,对GetSymbolFromObjectFile()的调用开始传递base_address的值.如果在第一个存储区域内找到帧程序计数器并且已经用零偏移映射了可执行映像,则该值可以变为零.这似乎是一种常见的情况.

GetSymbolFromObjectFile()中的另一个变化是添加了符号偏移调整的代码和新的检查:如果在所有调整之后symbol_offset等于零,则函数返回失败值,意味着"未找到符号".由于symbol_offset变量是从base_address计算的,因此该条件变得非常可能.

详情请见



1> Damian..:

我只是尝试过,它对我有用.
我可以看到h(),g(),f()的结果显示在堆栈跟踪中.

F1219 16:20:16.171772 20931 main.cpp:2] test
*** Check failure stack trace: ***
    @     0x7f951ee03e6d  (unknown)
    @     0x7f951ee05ced  (unknown)
    @     0x7f951ee03a5c  (unknown)
    @     0x7f951ee0663e  (unknown)
    @           0x40089a  h()
    @           0x4008af  g()
    @           0x4008bb  f()
    @           0x4008e1  main
    @     0x7f951e22e3d5  __libc_start_main
    @           0x4007a9  (unknown)

Process finished with exit code 134 (interrupted by signal 6: SIGABRT)

这是我的CMakeLists.txt文件

cmake_minimum_required(VERSION 3.13)
project(test_glog)

set(CMAKE_CXX_STANDARD 14)

include_directories(/usr/include)
link_libraries(glog)
add_executable(test_glog main.cpp)

当我编译时,它扩展到这个:

我在CentOS 7上并安装了以下库:

yum install glog-devel gflags-devel

以下是我如何构建它:

[user@cent1 build]$ make VERBOSE=1
/usr/bin/cmake3 -H/home/user/CLionProjects/test_glog -B/home/user/CLionProjects/test_glog/build --check-build-system CMakeFiles/Makefile.cmake 0
/usr/bin/cmake3 -E cmake_progress_start /home/user/CLionProjects/test_glog/build/CMakeFiles /home/user/CLionProjects/test_glog/build/CMakeFiles/progress.marks
make -f CMakeFiles/Makefile2 all
make[1]: Entering directory `/home/user/CLionProjects/test_glog/build'
make -f CMakeFiles/test_glog.dir/build.make CMakeFiles/test_glog.dir/depend
make[2]: Entering directory `/home/user/CLionProjects/test_glog/build'
cd /home/user/CLionProjects/test_glog/build && /usr/bin/cmake3 -E cmake_depends "Unix Makefiles" /home/user/CLionProjects/test_glog /home/user/CLionProjects/test_glog /home/user/CLionProjects/test_glog/build /home/user/CLionProjects/test_glog/build /home/user/CLionProjects/test_glog/build/CMakeFiles/test_glog.dir/DependInfo.cmake --color=
make[2]: Leaving directory `/home/user/CLionProjects/test_glog/build'
make -f CMakeFiles/test_glog.dir/build.make CMakeFiles/test_glog.dir/build
make[2]: Entering directory `/home/user/CLionProjects/test_glog/build'
[ 50%] Building CXX object CMakeFiles/test_glog.dir/main.cpp.o
/opt/rh/devtoolset-7/root/usr/bin/c++    -std=gnu++14 -o CMakeFiles/test_glog.dir/main.cpp.o -c /home/user/CLionProjects/test_glog/main.cpp
[100%] Linking CXX executable test_glog
/usr/bin/cmake3 -E cmake_link_script CMakeFiles/test_glog.dir/link.txt --verbose=1
/opt/rh/devtoolset-7/root/usr/bin/c++     CMakeFiles/test_glog.dir/main.cpp.o  -o test_glog -lglog 
make[2]: Leaving directory `/home/user/CLionProjects/test_glog/build'
[100%] Built target test_glog
make[1]: Leaving directory `/home/user/CLionProjects/test_glog/build'
/usr/bin/cmake3 -E cmake_progress_start /home/user/CLionProjects/test_glog/build/CMakeFiles 0

更新:我在vm中安装Debian ubuntu-18.04.1-desktop-amd64.iso并从源代码构建glog.您的示例现在显示:

$ ./a.out 
F0102 23:54:15.603329 10358 t.cc:2] test
*** Check failure stack trace: ***
    @     0x55c930b28d2c  google::LogMessage::Fail()
    @     0x55c930b28c74  google::LogMessage::SendToLog()
    @     0x55c930b285b5  google::LogMessage::Flush()
    @     0x55c930b2be66  google::LogMessageFatal::~LogMessageFatal()
    @     0x55c930b25820  google::thread_msg_data
    @     0x55c930b25835  google::thread_msg_data
    @     0x55c930b25841  google::thread_msg_data
    @     0x55c930b25867  google::thread_msg_data
    @     0x7ff9fbf2eb97  __libc_start_main
    @     0x55c930b256ea  google::thread_msg_data
    @              (nil)  (unknown)
Aborted (core dumped)

我可以看到我们尝试解决这个问题,所以我建议你用glog打开一个问题. https://github.com/google/glog/pull/347/commits/26459400f49850bda8e736882c6f22c2ce766761

我还尝试直接从命令链接构建它并显示设置.不确定glog库的构建设置是否会产生影响.

$ g++ t.cc -lglog --verbose
Using built-in specs.
COLLECT_GCC=g++
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/7/lto-wrapper
OFFLOAD_TARGET_NAMES=nvptx-none
OFFLOAD_TARGET_DEFAULT=1
Target: x86_64-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu 7.3.0-27ubuntu1~18.04' --with-bugurl=file:///usr/share/doc/gcc-7/README.Bugs --enable-languages=c,ada,c++,go,brig,d,fortran,objc,obj-c++ --prefix=/usr --with-gcc-major-version-only --program-suffix=-7 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-libmpx --enable-plugin --enable-default-pie --with-system-zlib --with-target-system-zlib --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64,mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu
Thread model: posix
gcc version 7.3.0 (Ubuntu 7.3.0-27ubuntu1~18.04) 
COLLECT_GCC_OPTIOnS='-v' '-shared-libgcc' '-mtune=generic' '-march=x86-64'
 /usr/lib/gcc/x86_64-linux-gnu/7/cc1plus -quiet -v -imultiarch x86_64-linux-gnu -D_GNU_SOURCE t.cc -quiet -dumpbase t.cc -mtune=generic -march=x86-64 -auxbase t -version -fstack-protector-strong -Wformat -Wformat-security -o /tmp/ccoFCYTb.s
GNU C++14 (Ubuntu 7.3.0-27ubuntu1~18.04) version 7.3.0 (x86_64-linux-gnu)
    compiled by GNU C version 7.3.0, GMP version 6.1.2, MPFR version 4.0.1, MPC version 1.1.0, isl version isl-0.19-GMP

GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
ignoring duplicate directory "/usr/include/x86_64-linux-gnu/c++/7"
ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"
ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/7/../../../../x86_64-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
 /usr/include/c++/7
 /usr/include/x86_64-linux-gnu/c++/7
 /usr/include/c++/7/backward
 /usr/lib/gcc/x86_64-linux-gnu/7/include
 /usr/local/include
 /usr/lib/gcc/x86_64-linux-gnu/7/include-fixed
 /usr/include/x86_64-linux-gnu
 /usr/include
End of search list.
GNU C++14 (Ubuntu 7.3.0-27ubuntu1~18.04) version 7.3.0 (x86_64-linux-gnu)
    compiled by GNU C version 7.3.0, GMP version 6.1.2, MPFR version 4.0.1, MPC version 1.1.0, isl version isl-0.19-GMP

GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
Compiler executable checksum: 1bfae38ae5df64de6196cbd8c3b07d86
COLLECT_GCC_OPTIOnS='-v' '-shared-libgcc' '-mtune=generic' '-march=x86-64'
 as -v --64 -o /tmp/ccvUzQBB.o /tmp/ccoFCYTb.s
GNU assembler version 2.30 (x86_64-linux-gnu) using BFD version (GNU Binutils for Ubuntu) 2.30
COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/7/:/usr/lib/gcc/x86_64-linux-gnu/7/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/7/:/usr/lib/gcc/x86_64-linux-gnu/
LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/7/:/usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/7/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/7/../../../:/lib/:/usr/lib/
COLLECT_GCC_OPTIOnS='-v' '-shared-libgcc' '-mtune=generic' '-march=x86-64'
 /usr/lib/gcc/x86_64-linux-gnu/7/collect2 -plugin /usr/lib/gcc/x86_64-linux-gnu/7/liblto_plugin.so -plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/7/lto-wrapper -plugin-opt=-fresolution=/tmp/ccNEOWk1.res -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lc -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lgcc --sysroot=/ --build-id --eh-frame-hdr -m elf_x86_64 --hash-style=gnu --as-needed -dynamic-linker /lib64/ld-linux-x86-64.so.2 -pie -z now -z relro /usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu/Scrt1.o /usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu/crti.o /usr/lib/gcc/x86_64-linux-gnu/7/crtbeginS.o -L/usr/lib/gcc/x86_64-linux-gnu/7 -L/usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu -L/usr/lib/gcc/x86_64-linux-gnu/7/../../../../lib -L/lib/x86_64-linux-gnu -L/lib/../lib -L/usr/lib/x86_64-linux-gnu -L/usr/lib/../lib -L/usr/lib/gcc/x86_64-linux-gnu/7/../../.. /tmp/ccvUzQBB.o -lglog -lstdc++ -lm -lgcc_s -lgcc -lc -lgcc_s -lgcc /usr/lib/gcc/x86_64-linux-gnu/7/crtendS.o /usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu/crtn.o
COLLECT_GCC_OPTIOnS='-v' '-shared-libgcc' '-mtune=generic' '-march=x86-64'

这是运行时的输出:

$ ./a.out 
F0106 12:07:11.753652 28547 t.cc:2] test
*** Check failure stack trace: ***
    @     0x55c500dedd2c  google::LogMessage::Fail()
    @     0x55c500dedc74  google::LogMessage::SendToLog()
    @     0x55c500ded5b5  google::LogMessage::Flush()
    @     0x55c500df0e66  google::LogMessageFatal::~LogMessageFatal()
    @     0x55c500dea820  google::thread_msg_data
    @     0x55c500dea835  google::thread_msg_data
    @     0x55c500dea841  google::thread_msg_data
    @     0x55c500dea867  google::thread_msg_data
    @     0x7f882d938b97  __libc_start_main
    @     0x55c500dea6ea  google::thread_msg_data
    @              (nil)  (unknown)
Aborted (core dumped)

更新2:glog开发人员Evgeny Prigorodov一直在研究这个问题并确定了问题.我相信这个问题很快就会解决.

所以这是在a93a451之后src/symbolize.cc中发生的事情:

堆栈跟踪中的每一行都在函数SymbolizeAndDemangle()中准备.它计算变量start_address/base_address并调用函数GetSymbolFromObjectFile(),它试图查找对应于给定帧指令指针(pc)的符号.

在v0.3.4中,对GetSymbolFromObjectFile()的调用传递了start_address的值,它是内存区域的起始地址,永远不能为零.GetSymbolFromObjectFile()没有检查start_address的值,只是将它用于两个符号表中的查找.

在v0.3.5中,对GetSymbolFromObjectFile()的调用开始传递base_address的值.如果在第一个存储区域内找到帧程序计数器并且已经用零偏移映射了可执行映像,则该值可以变为零.这似乎是一种常见的情况.

GetSymbolFromObjectFile()中的另一个变化是添加了符号偏移调整的代码和新的检查:如果在所有调整之后symbol_offset等于零,则函数返回失败值,意味着"未找到符号".由于symbol_offset变量是从base_address计算的,因此该条件变得非常可能.

详情请见


推荐阅读
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文概述了JNI的原理以及常用方法。JNI提供了一种Java字节码调用C/C++的解决方案,但引用类型不能直接在Native层使用,需要进行类型转化。多维数组(包括二维数组)都是引用类型,需要使用jobjectArray类型来存取其值。此外,由于Java支持函数重载,根据函数名无法找到对应的JNI函数,因此介绍了JNI函数签名信息的解决方案。 ... [详细]
  • 每当我尝试使用NEON16位浮点内在函数时都会收到此错误。我没有遇到其他数据类型内在函数的任何问题。是否可以在Android上使用NEON16位浮点内在函数? ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Android JSON基础,音视频开发进阶指南目录
    Array里面的对象数据是有序的,json字符串最外层是方括号的,方括号:[]解析jsonArray代码try{json字符串最外层是 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • 本文介绍了在MFC下利用C++和MFC的特性动态创建窗口的方法,包括继承现有的MFC类并加以改造、插入工具栏和状态栏对象的声明等。同时还提到了窗口销毁的处理方法。本文详细介绍了实现方法并给出了相关注意事项。 ... [详细]
  • 32位ubuntu编译android studio,32位Ubuntu编译Android 4.0.4问题
    问题一:在32位Ubuntu12.04上编译Android4.0.4源码时,出现了关于emulator的错误,关键是其Makefile里的 ... [详细]
  • 第2讲 Android Camera Native Framework 初识cameraserver进程
    本讲是AndroidCameraNativeFramework专题的第2讲,我们初识CameraServer,包括如下内容:Camera ... [详细]
  • 编写一个简单的内核驱动模块时报错 “/lib/modules/3.13.032generic/bulid: 没有那个文件或目录。 停止。”...
    编写一个简单的内核驱动模块1staticinthello_init()2{3printk(“hello,Iaminkernelnow\n”);4return0;5}6voidadd ... [详细]
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
author-avatar
有你真好-LOVE
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有