Makefile学习

makefile 完美教程 - WittXie - 博客园

Makefile由浅入深--教程、干货 - 知乎

选项          说明
-c              用于把源码文件编译成 .o 对象文件,不进行链接过程
-o              用于连接生成可执行文件,在其后可以指定输出文件的名称
-g              用于在生成的目标可执行文件中,添加调试信息,可以使用GDB进行调试
-Idir           用于把新目录添加到include路径上,可以使用相对和绝对路径,“-I.”、“-I./include”、“-I/opt/include”
-Wall         生成常见的所有告警信息,且停止编译,具体是哪些告警信息,请参见GCC手册,一般用这个足矣!
-w             关闭所有告警信息
-O             表示编译优化选项,其后可跟优化等级0\1\2\3,默认是0,不优化
-fPIC         用于生成位置无关的代码
-v              (在标准错误)显示执行编译阶段的命令,同时显示编译器驱动程序,预处理器,编译器的版本号

Makefile之cflags参数和ldflags参数

CFLAGS = -g -Wall -I./include -I./include/tinyalsa -Wl,--whole-archive -lpthread -Wl,--no-whole-archive -lc
-g:生成调试信息
-Wall:输出全部的告警信息
-I./include:添加头文件搜索目录./include
-I./include/tinyalsa:添加头文件搜索目录./include/tinyalsa
-Wl,--whole-archive -lpthread:将libpthread.so及以后的库中的所有符号都链接进可执行目标文件
-Wl,--no-whole-archive:关闭之前的-Wl,--whole-archive -lpthread 选项
LDFLAGS = -L./lib,将makefile当前目录下的、lib文件夹添加到库文件搜索目录

$(CC):makefile隐含变量,默认选择gcc编译器
$(CFLAGS):引用之前定义的CFLAGS变量,即编译选项参数
$(LDFLAGS):引用之前定义的LDFLAGS变量,即链接参数

$(CC) $(CFLAGS) $(LDFLAGS) main.c gfifo.c ./lib/libtinyalsa.a -o media_record -static -ldl -lstdc++ -lm -lpthread
使用定的编译器、编译选项参数、链接选项参数,编译.c文件,并使用静态方式链接制定的库文件,以及编译器目录下的libdl.a、libstdc++.a、libm.a、libpthread.a库文件生成 media_record 可执行目标文件。

你可能感兴趣的:(makefile,linux,学习)