Linux —— makefile文件的编写

一、源文件的编写

/* main.c */
#include "mytool1.h"
#include "mytool2.h"
int main(int argc,char **argv)
{
	mytool1_print("hello");
	mytool2_print("hello");
}
/* mytool1.h */
#ifndef _MYTOOL_1_H
#define _MYTOOL_1_H
	void mytool1_print(char *print_str);
#endif

/* mytool2.h */
#ifndef _MYTOOL_2_H
#define _MYTOOL_2_H
	void mytool2_print(char *print_str);
#endif
/* mytool1.c */
#include "mytool1.h"
#include 
void mytool1_print(char *print_str)
{
	printf("This is mytool1 print %s\n",print_str);
}

/* mytool2.c */
#include "mytool2.h"
#include 
void mytool2_print(char *print_str)
{
	printf("This is mytool2 print %s\n",print_str);
}

由于这个程序很短,我们可以这样编译:

$ gcc -c main.c -o main.o
$ gcc -c mytool1.c -o mytool1.o
$ gcc -c mytool2.c -o mytool2.o
$ gcc -o main main.o mytool1.o mytool2.o

makefile 文件的编写

但如果我们要重复修改文件内容,难道要多次编译?这个时候便产生了makefile来解决这个问题:

1、makefile 完整形式:

main:main.o mytool1.o mytool2.o
	gcc -o main main.o mytool1.o mytool2.o
main.o:main.c mytool1.h mytool2.h
	gcc -c main.c -o main.o
mytool1.o:mytool1.c mytool1.h
	gcc -c mytool1.c -o mytool1.o
mytool2.o:mytool2.c mytool2.h
	gcc -c mytool2.c -o mytool2.o

2、makefile 参数化简形式:

  • $@–目标文件
  • $^–所有的依赖文件
  • $<–第一个依赖文件.
main:main.o mytool1.o mytool2.o
	gcc -o $@ $^
main.o:main.c mytool1.h mytool2.h
	gcc -c $<  -o $@
mytool1.o:mytool1.c mytool1.h
	gcc -c $< -o $@
mytool2.o:mytool2.c mytool2.h
	gcc -c $< -o $@

3、makefile 缺省化简形式:

main:main.o mytool1.o mytool2.o
	gcc -o $@ $^
..c.o:
	gcc -c $<

4、执行makefile

$ make

你可能感兴趣的:(Linux)