关闭

一个简单的Makefile

349人阅读 评论(0) 收藏 举报

一个简易的小万能Makefile

target := hello
obj = $(patsubst *.c, *.o, $(wildcard *.c))
$(target): $(obj)
        gcc -o $(target) $(obj) 
clean:
        rm -r $(target) *.o
exp

#include <stdio.h>

int main(int argc, char *argv[])
{
        printf("Hello, world\n");

        return 0;
}
do

root@ubuntuServer:~/test# make
gcc -o hello  hello.c 
root@ubuntuServer:~/test# ./hello 
Hello, world
root@ubuntuServer:~/test# 
分析

target += hello
定义一个变量target,想要输出怎么样的可执行程序,替换hello就可以了。对于:=附加操作符,表明hello是立即变量

obj = $(patsubst *.c, *.o, $(wildcard *.c))
$(patsubst a, b, c)表示替换通配符,意思是说将c中的a替换成b;$(wildacrd *.c)是扩展通配符,即将当前目录下的所有.c文件的后缀换成.o

$(target): $(obj)
        gcc -o $(target) $(obj) 
这条是执行规则,生成可执行程序

最后一条伪指令用于清理

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:8811次
    • 积分:182
    • 等级:
    • 排名:千里之外
    • 原创:8篇
    • 转载:0篇
    • 译文:0篇
    • 评论:0条
    文章分类
    文章存档