1 #include<iostream> 2 using namespace std; 3 int main() 4 { 5 cout<<"hello world!"<<endl; 6 return 0; 7 }
[zsj@localhost aa]$ ldd test linux-vdso.so.1 => (0x00007ffff64ac000) libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x0000003a67000000) libm.so.6 => /lib64/libm.so.6 (0x0000003a5b000000) libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x0000003a66000000) libc.so.6 => /lib64/libc.so.6 (0x0000003a5a400000) /lib64/ld-linux-x86-64.so.2 (0x0000003a59c00000)
gcc/g++ 在执行编译时,需要4步
1 预处理,生成.i的文件[使用-E参数]
2 将预处理后的文件不转换成汇编语言,生成文件.s[使用-S参数]
[zsj@localhost aa]$ g++ -E test.cpp >> test.i [zsj@localhost aa]$ g++ -S test.i >> test.s [zsj@localhost aa]$ g++ -c test.s >>test.o [zsj@localhost aa]$ g++ test.o -o test [zsj@localhost aa]$ ls test test.cpp test.i test.o test.s [zsj@localhost aa]$ ./test hello world!
注意:如果用gcc编译C++源文件时,加选项:-lstdc++,否则使用了C++操作的文件编译会出错
[zsj@localhost aa]$ gcc test.cpp -o test /tmp/cceNJsOV.o: In function `main‘: test.cpp:(.text+0xa): undefined reference to `std::cout‘ test.cpp:(.text+0xf): undefined reference to `std::basic_ostream<char, std::char_traits<char> >& std::operator<< <std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&, char const*)‘ test.cpp:(.text+0x14): undefined reference to `std::basic_ostream<char, std::char_traits<char> >& std::endl<char, std::char_traits<char> >(std::basic_ostream<char, std::char_traits<char> >&)‘ test.cpp:(.text+0x1c): undefined reference to `std::basic_ostream<char, std::char_traits<char> >::operator<<(std::basic_ostream<char, std::char_traits<char> >& (*)(std::basic_ostream<char, std::char_traits<char> >&))‘ /tmp/cceNJsOV.o: In function `__static_initialization_and_destruction_0(int, int)‘: test.cpp:(.text+0x4a): undefined reference to `std::ios_base::Init::Init()‘ test.cpp:(.text+0x4f): undefined reference to `std::ios_base::Init::~Init()‘ /tmp/cceNJsOV.o:(.eh_frame+0x12): undefined reference to `__gxx_personality_v0‘ collect2: ld 返回 1 [zsj@localhost aa]$ gcc -lstdc++ test.cpp -o test [zsj@localhost aa]$ ./test hello world!
g++常用的编译选项
编译选项 | 含义 |
-Wall | 显示所有警告信息(warning all) |
-g | 在编译的时候,产生调试信息(gdb时用) |
-O0 -O1 -O2 -O3 |
编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高 |
-Idir | 在你是用#include"file"的时候,gcc/g++会先在当前目录查找你所指定的头文件,如 果没有找到,他回到缺省的头文件目录找,如果使用-I制定了目录,他 会先在你所指定的目录查找,然后再按常规的顺序去找。 |
-Ldir | 指定编译的时候,搜索库的路径。比如你自己的库,能用他指定目录,不然 编译器将只在标准库的目录找。这个dir就是目录的名称。 |
-llibrary | 指定编译的时候使用的库 |
-o | 指定目标名称,缺省的时候,gcc 编译出来的文件是a.out |
-fPIC |
作用于编译阶段,告诉编译器产生与位置无关代码(Position-Independent Code), 通常和-shared一起,用来编译动态链接库。 g++ -shared -fPIC -o test.so test.cpp |
-D
|
定义宏,例如-DAAA=1,-DBBBB 等价于 #define AAA 1 |
-U |
取消宏定义,例如-UAAA |
gdb
命令 | 命令缩写 | 命令说明 |
list | l | 默认显示10行内容 list <line-number> 显示参数行之前和之后的10行 list <line1,line2> line1为显示起始行,line2为显示结束行 |
file | f | 装入需要调试的程序 |
break | b | break <line-number> 指定行处设置断点 break <function-name> 指定函数前设置断点 break <line-number> if <conditional expression> 使用表达式设置断点 break <filename:line-number> break <filename:function-name> 如果程序由很多源文件构成,可以在各个源文件中设置断点 |
info | i |
info break 显示当前断点信息 info registers 查看寄存器情况 info locals 查看局部变量 |
run | r | 开始运行程序 run <arg1 arg2...> 使用带参数run后,如果再次使用不带参数run,gdb就再次使用前一条run命令的参数,如果修改参数,使用set args命令 使用show args命令可以查看缺省参数列表 |
start | st | 开始执行程序,在main函数的第一条语句前面停下来 |
kill | k | 终止正在调试的程序 |
display | disp | 跟踪查看某个变量,每次停下来都显示它的值 |
step | s | 执行下一条语句,如果该语句为函数调用,则进入函数执行其中的第一条语句 |
next | n | 执行下一条语句,如果该语句为函数调用,不会进入函数内部执行(即不会一步步地调试函数内部语句) |
continue | c | 继续程序的运行,直到遇到下一个断点 |
p | 打印内部变量值print <file::varable-name> print <function::varable-name> 观察全局变量值 print func(argq,arg2,...) 对程序中的函数进行调试 print <expression> 查看表达式的值 print <array-name>查看数组的值 print <第一个内存地址的值@需要查看的内存长度> eg int *array=(int*) malloc(len*sizeof(int));p *array@len 查看连续内存地址值 变量输出格式 p/a i 按照16进制显示变量i的值 p/c i 按照字符格式显示变量i的值 p/f i按照浮点数的格式显示变量的值 p/t i 按照二进制显示变量i的值 |
|
watch | watch <condition> 在程序中设置一个观察点,condition是触发观察点的条件 | |
set | set varname=v 设置变量的值 show convenience查看当前设置的所有环境变量 | |
backtrace | bt | 产看函数调用信息(堆栈) |
frame | f | 查看栈帧 |
singal | singal signum 在某处产生一个信号(具体用法后续整理) |
原文:https://www.cnblogs.com/lovehelenmore/p/10800318.html