两个简单的makefile

1、把目录下的每一个.c文件都单独编译成一个可执行文件

SRCS:=$(wildcard *.c)
# EFLS:=$(SRCS:%.c=%)
EFLS:=$(patsubst %.c,%,$(srcs))
CC:=gcc
CFLAGS:=-Werror

all:$(EFLS)

%:%.c
	$(CC) $< -o $@ $(CFLAGS)
clean:
	rm -rf $(EFLS)

2、把目录下的所有.c文件 编译成一个可执行程序

# main:main.o print.o
# 	gcc main.o print.o -o main
# main.o:main.c 
# 	gcc -c main.c
# print.o:print.c
# 	gcc -c print.c
# rebuild:clean main
# clean:
# 	rm -rf *.o main

# out:=main
# main:main.o print.o
# 	gcc main.o print.o -o $(out)
# main.o:main.c 
# 	gcc -c main.c
# print.o:print.c
# 	gcc -c print.c
# rebuild:clean main
# clean:
# 	rm -rf *.o $(out)

out:=main
# objs:= main.o print.o
srcs:=$(wildcard *.c)
# objs:=$(patsubst %.c,%.o,$(srcs)) 
objs:=$(srcs:%.c=%.o)
CC:=g++
CFLAGS:= -g
$(out):$(objs)
	$(CC) $^ -o $@
# %.o:%.c #可以删除 make有隐式规则 当.o文件发现依赖于.c 时,会自动把推荐的.c编译成.o 而且推荐这种方式,因为 CFLAGS也是隐式规则
# 	$(CC) -c $^ -o $@ $(CFLAGS)
rebuild:clean main
clean:
	rm -rf $(objs) $(out)

你可能感兴趣的:(c语言编程,c#,开发语言)