千万不要打log去调试,你以为不怎么浪费时间,其实很浪费时间!!!
gdb + core文件才是最节省时间的!!!!
1.首先一定要设置set(CMAKE_CXX_FLAGS_RELEASE “-O3 -Wall -g”) -g才会加入调试信息,你可以把CMAKE_BUILD_TYPE依旧设为Release,但是-g一定要加上,不然你什么信息都看不到!
2.生成core文件
1.在linux终端执行以下命令 ulimit -c unlimited
2.运行sysctl -w kernel.core_pattern=/tmp/core-%e.%p.%h.%t
一个是放开core文件大小的限制,我们平时跑代码没有生成core文件是因为linux系统自动限制core文件大小为0kb。
二是指定core文件生成的位置在/tmp下面,名称是core-标识进程的参数值,你要可以设置其他,不重要。
3.代码运行,core dump之后就会生成core 文件。
4. 在终端运行 gdb -c core文件
大概率你会出现 ??我们需要加载符号符号表。
在gdb 里面 输入命令
symbol-file 应用的执行程序(绝对路径)
sharedlibrary
注意是在gdb里面输入的,这样就会从二进制程序文件及其引入的共享库中加载符号,再输入bt ,这样就OK了。一下子就定位到哪行代码出了问题。
非常方便!