一、 gcc基本语法
gcc -o 文件名(不带后缀) 源文件名
gcc -v -o a 1.c 显示详细的编译信息
编译过程如下:
/usr/lib/gcc/x86_64-linux-gnu/10/cc1
** as**
/usr/lib/gcc/x86_64-linux-gnu/10/collect2
二、编译相关
预处理
处理宏定义等,如图
gcc -E
#include<stdio.h>
#define ABC 10
int main()
{
int a=ABC;
printf("new day \n");
return 0;
}
预处理指令
gcc -E -o 2.c 1.c
2.c文末可以看到代码如下
int main()
{
int a=10;
printf("new day \n");
return 0;
}
编译
gcc -S
调用了cc1文件,生成了一个.s文件(汇编语言)
gcc -S -o a.s 1.c
汇编
gcc -c
调用as 生成二进制文件
gcc -c -o a.i 1.c
链接
gcc -o
三、预处理问题
#include<fun.h>
与#include"fun"
<>在库里找
“”在当前文件夹下与库里都找
当一个头文件不在当前文件夹下,而在其他路径时,可使用
gcc -I 文件路径
如在1.c中加入
#include<fun.h>
在1.c所在的文件夹下并没有fun.h这个文件,fun.h位于该文件夹下的fun文件夹中,可用
gcc -I -o 2 1.c
在处理宏定义时也有一个注意的问题
#include<stdio.h>
#define ABC 10+8
int main()
{
printf("%d",ABC*5);
return 0;
}
#include<stdio.h>
#define ABC (10+8)
int main()
{
printf("%d",ABC*5);
return 0;
}
前者输出50,后者输出90
预定义宏
__FUNCTION__
__LIFE__
__FILE__
一般用于工程量大的时候调试用的
例程如下:
#include<stdio.h>
int main()
{
printf("%s %s %d",__FUNCTION__,__LIFE__,__FILE__);
return 0;
}
可以得到printf所在位置的函数名,文件名,行数的信息。
切换调试版本和发行版本的编译方法
有时候程序里部分是用来调试用的代码,在正式使用时不适合表示出来,一行一行去//太过繁琐,可以通过一个宏定义来解决
#include<stdio.h>
#define ABC 10
int main()
{
#ifdef ABC
printf("DE_BUG\n");
#endif
printf("word\n");
return 0;
}
这样可以通过修改宏定义来一键开关debug,但这样要修改源文件,我们还有另一种更好的方法:
gcc -D
在源文件中删去宏定义ABC 的语句,如果我们想进入调试版本,可以:
gcc -DABC -o 2 1.c
切记D与宏定义名直接相连。