0
点赞
收藏
分享

微信扫一扫

MakeFile study(一)

zhaoxj0217 2022-03-12 阅读 52
linux

c编译指令

gcc -o /*module*/ /*filename1.c*/ /*filename2.c*/ /*filename3.c*/ -I.

-c,只编译,不链接成为可执行文件,编译器只是由输入的.c等源代码文件生成.o为后缀的目标文件,通常用于编译不包含主程序的子程序文件。

-o output_filename,确定输出文件的名称为output_filename,同时这个名称不能和源文件同名。如果不给出这个选项,gcc就给出预设的可执行文件a.out。

-g,产生符号调试工具(GNU的gdb)所必要的符号资讯,要想对源代码进行调试,我们就必须加入这个选项。

-O,对程序进行优化编译、链接,采用这个选项,整个源代码会在编译、链接过程中进行优化处理,这样产生的可执行文件的执行效率可以提高,但是,编译、链接的速度就相应地要慢一些。

-O2,比-O更好的优化编译、链接,当然整个编译、链接过程会更慢。

创建makefile(linux)

touch makefile
vim makefile

makefile文件的内容如下:

/*module*/:/*filename1.c*/ /*filename2.c*/ /*filename3.c*/
	gcc -o /*module*/:/*filename1.c*/ /*filename2.c*/ /*filename3.c*/ -I.

创建完成后,使用make即可运行编译出module;
注意,在编写上一个makefile的时候,需要在gcc前加一个tab;

优化makefile

variable1=gcc
variable2=-I.

%.o:%.c /*filename1.h*/
	$(variable1) -c -o $@ $< $(variable2)
/*module*/:/*filename1.o*/ /*filename2.o*/
	$(variable1) -o $@ $^ $(variable2)

$@ 表示目标文件,即左边的内容;

$^ 表示所有的依赖文件,即右边的所有文件;

$< 表示第一个依赖文件,即右边的第一个文件;

$% 仅当目标是函数库文件中,表示规则中的目标成员名。

再次优化makefile

variable1=gcc
variable2=-I.
variable3=/*filename1.h*/
variable4=/*filename1.o*/ /*filename2.o*/
variable5=/*module*/


%.o:%.c $(variable3)
	$(variable1) -c -o $@ $< $(variable2)
$(variable5):$(variable4)
	$(variable1) -o $@ $^ $(variable2)

通过变量替换掉了编译命令中的一些字符;因变量最终可以是全局变量,那么最后的makefile文件为:

%.o:%.c $(variable3)
	$(variable1) -c -o $@ $< $(variable2)
$(variable5):$(variable4)
	$(variable1) -o $@ $^ $(variable2)
举报

相关推荐

0 条评论