打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
简易Makefile
我们在Linux环境下开发程序,少不了要自己编写Makefile,一个稍微大一些的工程下面都会包含很多。c的源文 件。
    
    如果我们用gcc去一个一个编译每一个源文件的话,效率会低很多,但是如果我们可以写一个Makefile,那么只需要执行一个make就OK了,这 样大大提高了开发效率。
    
    但是Makefile的语法规则众多,而且缺乏参考资料,对于初学者来说,写起来还是有一定的难度,往往令很多人望而生畏。
    
    下面我 们介绍一个比较通用而且简洁的Makefile,大家只要对它稍作修改就可以用在你们自己的工程里了。
    
    现在假设我们有一个工程叫my_project,工程源码目录下面有app1.c,app2.c,app3.c以及main.c这五个源文件。我们现在需要编译出app1.o,app2.o,app3.o以及main.o,然后再把这些。o文件链接成为一个ELF格式的可执行程序叫做my_app.我们先看一个最简单的Makefile如何编写:
    
    my_app : main.o, app1.o, app2.o, app3.o, app4.o
    
    gcc –o my_app main.o app1.o, app2.o, app3.o, app4.o
    
    main.o : main.c
    
    gcc –c main.c
    
    app1.o : app1.c
    
    gcc –c app1.c
    
    app2.o : app2.c
    
    gcc –c app2.c
    
    app3.o : app3.c
    
    gcc –c app3.c
    
    clean :
    
    rm main.o app1.o, app2.o, app3.o, app4.o
    
    这是一个傻瓜式的Makefile,不灵活,而且不具备可复制性,想象一个如果我们的工程下面有50个源文件,那岂不是要一个一个写出来。
    
    我们的目标是写一个Makefile,只要稍作修改就可以在各个工程之间通用。
    
    下面这个Makefile就可以满足这个要求:
    
    SRCS = $(wildcard *.c)
    
    OBJS = $(SRCS:.c = .o)
    
    CC = gcc
    
    INCLUDES = -I/×××
    
    LIBS = -L/×××
    
    CCFLAGS = -g -Wall -O0
    
    my_app : $(OBJS)
    
    $(CC) $^ -o $@ $(INCLUDES) $(LIBS)
    
    %.o : %.c
    
    $(CC) -c $< $(CCFLAGS)
    
    clean:
    
    rm *.o
    
    .PHONY:clean
    
    大家看这个Makefile和前一个比起来是不是简洁很多,当然理解起来不如上一个那么直观。
    
    实际上编写 Makefile就是为了提高我们的工作效率,而不是增加我们的工作量。
    
    因此Makefile为我们提供了很多强大的功能,比如定义变量,使用通配符等 等。只要合理利用,就可以达到事半功倍的效果。
    
   


    
    下面我们一条一条分析这个Makefile:
    
    SRCS = $(wildcard *.c)
    
    这条语句定义了一个变量SRCS,它的值就是当前面目录下面所有的以。c结尾的源文件。
    
    OBJS = $(SRCS:.c = .o)
    
    这里变量OBJS的值就是将SRCS里面所有。c文件编译出的。o目标文件
    
    CC = gcc
    
    变量CC代表我们要使用的编译器
    
    INCLUDES = -I/×××
    
    LIBS = -L/×××
    
    这里指定除了编译器默认的头文件和库文件的路径之外需要额外引用的头文件路径以及库的路径(×××表示路径)。
    
    CCFLAGS = -g -Wall -O0
    
    CCFLAGS变量存放的是编译选项
    
    my_app : $(OBJS)
    
    $(CC) $^ -o $@ $(INCLUDES) $(LIBS)
    
    my_app依赖于所有的。o文件,$^代表$(OBJS),$@代表my_app
    
    %.o : %.c
    
    $(CC) -c $< $(CCFLAGS)
    
    将所有的。c源代码编译成。o目标文件,这样写是不是很省事?
    
    clean:
    
    rm *.o
    
    在执行make clean之后删除所有编译过程中生成的。o文件。
    
    .PHONY:clean
    
    每次执行make clean时都要执行rm *.o命令
    
    这个Makefile就具备灵活的通用性,我们只要对它稍作修改就可以用在自己的工程里面。当然Makefile还有很多强大的功能,需要我们进一步学习。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
makefile .d的解释
makefile 文件一步一步演变
Linux makefile使用基础
实用make最佳实践
Makefile自动依赖
nginx架构详解(50%)
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服