makefile
来源:互联网 发布:算法与程序设计 pdf 编辑:程序博客网 时间:2024/05/16 15:09
请注意(提示):
gcc,rm等操作语句的开头必须要添加一个tab空格,否则会报错 missing separator。
//第一次基本的
#生成test可执行文件,它的依赖于main.o func.o,也就是说生成test你得先生成它们
#2行:gcc前边必须是tab(Tab键空格),表示编译生成test
test:func.o main.o
gcc -o test func.o main.o
func.o:func.c
gcc -c func.c
main.o:main.c
gcc -c main.c
clean:
rm func.o main.o
注意可能没有编译到clean来,需要make clean
//第二次 :宏来替代N个
#定义一个宏
objects = main.o func.o
test: $(objects)
gcc -o test $(objects)
func.o:func.c
gcc -c func.c
main.o:main.c
gcc -c main.c
clean:
rm $(objects)
第三次:make的“隐晦规则”。
objects = main.o func.o
test: $(objects)
gcc -o test $(objects)
main.o:func.h
func.o:func.h
.PHONY : clean
clean:
rm $(objects)
.PHONY表示:clean是个伪目标文件。
向make说明,不管是否有这个文件,这个目标就是 伪目标
表示仅仅删除该伪目标
---未成功
第四次:替代
objects = main.o func.o
test: $(objects)
$(objects):%.o:%.c
gcc -c $< -o $@
#gcc -c test $(objects)
#.PHONY : clean
clean :
rm $(objects)
$<:表示源文件 *.c
$@:表示目标文件 *.o
也可以将第一行 objects = main.o func.o
替换为:
objects_all = main.o func.o func.h
objects = $(filter %.o,$(objects_all))
$(filter %.o,$(objects_all))
表示用makefile中的filter函数,只取objects_all中的*.o文件
说明:
如果你想让make不理那些无法读取的文件,而继续执行,你可以在include前加一个减号“-”。如:
-include <filename>
GNU的make工作时的执行步骤入下:
读入所有的Makefile。
读入被include的其它Makefile。
初始化文件中的变量。
推导隐晦规则,并分析所有规则。
为所有的目标文件创建依赖关系链。
根据依赖关系,决定哪些目标要重新生成。
执行生成命令。
1-5步为第一个阶段,6-7为第二个阶段。第一个阶段中,如果定义的变量被使用了,那么,make会把其展开在使用的位置。但make并不会完全马上展开,make使用的是拖延战术,如果变量出现在依赖关系的规则中,那么仅当这条依赖被决定要使用了,变量才会在其内部展开。
targets : prerequisites
command
...
或是这样: targets : prerequisites ; command
command
command是命令行,如果其不与“target:prerequisites”在一行,那么,必须以[Tab键]开头,如果和prerequisites在一行,那么可以用分号做为分隔。
如果命令太长,你可以使用反斜框(‘/’)作为换行符。make对一行上有多少个字符没有限制。规则告诉make两件事,文件的依赖关系和如何成成目标文件。
波浪号(“~”)字符在文件名中也有比较特殊的用途。如果是“~/test”,这就表示当前用户的$HOME目录下的test目录。而“~hchen/test”则表示用户hchen的宿主目录下的test目录。(这些都是Unix下的小知识了,make也支持)而在Windows或是MS-DOS下,用户没有宿主目录,那么波浪号所指的目录则根据环境变量“HOME”而定。
objects = *.o
上面这个例子,表示了,通符同样可以用在变量中。并不是说[*.o]会展开,不!objects的值就是“*.o”。Makefile中的变量其实就是C/C++中的宏。如果你要让通配符在变量中展开,也就是让objects的值是所有[.o]的文件名的集合,那么,你可以这样: objects := $(wildcard *.o)
.PHONY: cleanall cleanobj cleandiff
cleanall : cleanobj cleandiff
rm program
cleanobj :
rm *.o
cleandiff :
rm *.diff
使用:
make cleanall
make cleanobj
make cleandiff
bigoutput littleoutput : text.g
generate text.g -$(subst output,,$@) > $@
上述规则等价于:
bigoutput : text.g
generate text.g -big > bigoutput
littleoutput : text.g
generate text.g -little > littleoutput
其中,-$(subst output,,$@)中的“$”表示执行一个Makefile的函数,函数名为subst,后面的为参数。关于函数,将在后面讲述。这里的这个函数是截取字符串的意思,“$@”表示目标的集合,就像一个数组,“$@”依次取出目标,并执于命令。
他人的:
CFLAGS := -g -Wall -fPIC -DPIC -I./
SOFLAGS := -shared -Wl,-E
LDFLAGS := -L./ -pthread
GCC=gcc
TARGET := sip.so
COBJS = ./Md5Codec.o/
./SipApi.o/
./SipHandle.o/
./SipMessage.o/
./SipStack.o/
./SipCall.o/
./SipLine.o/
./SipSender.o/
./SipRecvhandle.o/
./sdp.o/
./log.o/
#module sip
$(TARGET):$(COBJS)
$(GCC) $(SOFLAGS) $(COBJS) -o $(TARGET)
$(COBJS):%.o:%.c
$(GCC) $(CFLAGS) -c $< -o $@
$(LOGOBJS):%.o:%.c
$(GCC) $(CFLAGS) -c $< -o $@
clean:
rm $(COBJS) $(TARGET) -rf
- Makefile
- Makefile
- makefile
- makefile
- makefile
- Makefile
- Makefile
- Makefile
- Makefile
- Makefile
- Makefile
- makefile
- Makefile
- makefile
- Makefile
- makefile
- makefile
- makefile
- 开发培训体会——写好代码的一些基本原理
- Symbian 函数或类与头文件和LIB库对照表
- Visual Studio 2008 每日提示(三十一)
- GridView 删除/更新/取消/
- 差分信号放大
- makefile
- 出师表《80后传》
- SEO完全手册之title优化
- ARM处理器系统初始化编程注意事项
- 创建MP3解码器 - 采用Symbian中MAD(MPEG音频解码库)用法
- IT业10大虚假神话:盖茨并非编程神童
- Drag 和 Drop 在 JavaScript 中的使用
- 让指针不再困扰你
- IT类科技公司门户网站建设方案