一个简单的Makefile

一个简易的小万能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) 
这条是执行规则,生成可执行程序

最后一条伪指令用于清理

阅读更多
个人分类: linux code
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

一个简单的Makefile

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭