目录
前言
假定阅读读者,熟悉 C/C ++, 熟悉基本的 Linux命令,文中省略了相当的 Linux指令
新建一个C++项目
项目中,文件很多,不可能直接写 g++ -o main main.cpp …… 来编译项目,需要 makefile 文件。这个文件顾名思义就是支持 make 命令的文件 233
1.新建 项目文件夹 linuxtest 里面 再新建main.cpp, one.h, one.cpp
//为了方便,我将项目文件放在目录最外层
/linux/multthread/main.cpp
/linux/multthread/one.h
/linux/multthread/one.cpp
main.cpp
//main.cpp
#include<iostream>
#include"one.h" //依赖项
using namespace std;
class A; //前置声明
void func(int *a)
{
//assert(false);
for(int i=0; i<10; ++i)
{
a[i] = 123; //为了让程序崩溃,以产生 core dump 文件故意越界
}
//A* ptrA = nullptr;
//ptr->get(); //使用空指针让程序崩溃
}
int main(int arg, char** args)
{
int a[3]={1,2,3};
func(a);
return 0;
}
one.h
#ifndef ONE_H
#define ONE_H
class A
{
public:
A() = default;
explicit A(int a);
private:
int a;
};
#endif
one.cpp
#include"one.h"
A::A(int tmp)
{
a = tmp;
}
为项目编写 makefile 文件
1.和 main.cpp 位于同一目录
#
#main obj file
main: main.o one.o
g++ -g -O0 -std=c++14 -o $@ $^
#main cpp file
main.o: main.cpp
g++ -std=c++14 -c $^
#other cpp file
one.o: one.cpp
g++ -std=c++14 -c $^
#remove all obj file
clean:
rm -rf *.o
必要的说明:
第3行 main: main 为输出的程序名,之后是依赖的目标文件
第4行 $@ 表示所有目标文件,$^表示所有的依赖项
注意:这里为了编译之后的调试我增加了 -g -o0 选项-g 增加调试信息,-o 表示编译器对代码的优化级别,0 最低
第13行clean: 删除所有的目标文件
2.编译代码
make 一下就行了,make clean 可以用来清理
启用 core_dump 文件生成
.代码编写完成,还需要为调试做出准备。Linux 和 Windows 一样,程序崩溃默认不会生成dump文件。不一样的是 Linux 需要修改系统设置来生成,而 Windows 可以在代码中完成这一工作。
1.修改 /etc/profile 文件,添加这一行 ulimit-c unlimited
为了让修改生效 还需要命令
. /etc/profile
2.修改 core dump 生成路径
echo /coredump/core.%e.%p> /proc/sys/kernel/core_pattern //e 执行程序名,p 进程id
生成在程序的当前路径:
echo core.%e.%p> /proc/sys/kernel/core_pattern
3.执行文件,让它生成dump文件
注意:我这里 文件带上了 时间戳,
GDB调试
1.yum install gdb //安装 gdb
yum install glibc
yum install libgcc
yum install libstdc++
2.到设置好的dmp文件目录 coredump 下 执行命令
gdb /linuxtest/multthread/main core.main.8098
命令格式 gdb 执行程序 转储文件
3.在执行 bt 可以看到堆栈信息,这能看到函数的执行顺序
这张图,是数组越界,
这张图,是空对象,一个空A类指针尝试调用成员函数。