简单makefile示例

Makefile

cmd:linux

- g++c++

 

相信在linux下编程的没有不知道makefile的,刚开始学习linux平台下的东西,了解了下makefile的制做,以为有点东西能够记录下。shell


下面是一个极其简单的例子:
如今我要编译一个Hello world,须要以下三个文件:
1. print.h编程

#include<stdio.h>  
void printhello();  

 

2. print.cide

1 #include"print.h"  
2 void printhello()  
3 {  
4     printf("Hello, world\n");  
5 }  

 

3. main.c学习

1 #include "print.h"  
2 int main(void)  
3 {  
4     printhello();  
5     return 0;  
6 }  

 

好了,很简单的程序了。若是咱们想要编译成功须要哪些步骤呢?
我认为在这里须要理解的就两步:
  #  为每个 *.c文件生成 *o文件。
  #  链接每个*o文件,生成可执行文件。
下面的makefile 就是根据这样的原则来写的。ui

 

一:makefile 雏形:

 
#makefile的撰写是基于规则的,固然这个规则也是很简单的,就是:
#target : prerequisites 
  command  //任意的shell 命令spa

实例以下:makefile文件内容:c++11

helloworld : main.o print.o #helloword 就是咱们要生成的目标  
    g++ -std=c++11 -o helloworld main.o print.o#shell命令,最前面的必定是一个tab键  
mian.o : mian.c print.h  
    g++ -std=c++11 -c main.c  
print.o : print.c print.h  
    g++ -std=c++11 -c print.c  
  
clean :            
    rm helloworld main.o print.o  

OK,一个简单的makefile制做完毕,现成咱们输入 make,自动调用Gcc编译了,输入 make clean就会删除 hellowworld mian.o print.ocode


二:小步改进:


在上面的例子中咱们能够发现 main.o print.o 被定义了多处,咱们是否是能够向C语言中定义一个宏同样定义它呢?固然能够:
修改后的文件:

 1 objects =  main.o print.o #应该叫变量的声明更合适  
 2 helloworld : $(objects)    #声明了变量之后使用就要$()了  
 3     g++ -std=c++11 -o helloworld$(objects)  
 4 mian.o : mian.c print.h  
 5     g++ -std=c++11 -c main.c  
 6 print.o : print.c print.h  
 7     g++ -std=c++11 -c print.c  
 8       
 9 clean :            
10     rm helloworld $(objects)  

  

修改完毕,这样使用了变量的话在不少文件的工程中就能体现出方便性了。


三:再进一步:


  再看一下,为没一个*.o文件都写一句gcc -c main.c是否是显得多余了,
能不能把它干掉?并且 main.c 和print.c都须要print.h,为每个都写上是
不是多余了,能不能再改进?
能,固然能了:makefile内容:

1 objects =  main.o print.o  
2 helloworld : $(objects)   
3     g++ -std=c++11 -o helloworld$(objects)  
4       
5 $(objects) : print.h    # 都依赖print.h  
6 mian.o : mian.c         #干掉了gcc -c main.c 让Gun make自动推导了。  
7 print.o : print.c       
8 clean :            
9     rm helloworld $(objects)  
相关文章
相关标签/搜索