以下是Makefile的基本模板
#指定编译器
CC = g++
#指定编译参数
CFLAGS = -std=c++11
#指定头文件路径,此处用于指定非标准库的头文件路径
INC = -I./ -I /usr/include
#指定要链接的动态库或静态库 -L是指定动态库路径,非标准的动态库需要此参数
LIBS = -lm -ldl -L/mylibs/xxx -lxxx
#把上面放一起
CXXFLAGS = ${CFLAGS} ${INC} ${LIBS}
#指定生成可执行文件名称
EXEC = a.out
#指定由哪些文件来生成可执行文件
OBJS = xxx1.o xxx2.o
#make执行动作
${EXEC} : ${OBJS}
${CC} -o $@ $^
#make clean动作
clean:
rm -rf ${OBJS}
#中间文件的生成
%.o:%.c
$(CC) $(CXXFLAGS) $(INC) -o $@ -c $<
不生成中间.o文件
#指定编译器
CC = g++
#指定编译参数
CFLAGS = -std=c++11
#指定头文件路径,此处用于指定非标准库的头文件路径
INC = -I./ -I /usr/include
#指定要链接的动态库或静态库 -L是指定动态库路径,非标准的动态库需要此参数
LIBS = -lm -ldl -L/mylibs/xxx -lxxx
#把上面放一起
CXXFLAGS = ${CFLAGS} ${INC} ${LIBS}
#指定生成可执行文件名称
EXEC = a.out
#指定由哪些文件来生成可执行文件
COBJS = xxx1.c xxx2.c
#make执行动作
all:
$(CC) -o $(EXEC) $(COBJS) $(CXXFLAGS)
#make clean动作
clean:
rm -rf ${OBJS}
关于生成 **.o 文件(只编译未链接文件);若是在大型项目中,只修改了其中一个文件的内容,那么没必要全部文件重新编译,只需编译修改部分即可。此时就推荐使用先编译生成 *.o文件 ; 再链接。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架