Linux 系统中我们进行c语言开发,小的程序通常是直接使用编译命令来编译单个文件,但是程序大的时候,通常不止一个文件,怎样制作工程的makefile文件来方便编译呢?
本问先讲述makefile文件的基本格式,然后用以个实例来验证制作一个makefile文件编译工程
注意:一般我们通过条件编译技巧来避免重复包含头文件(见实例的#ifndef等命令)
makefile 文件的基本结构是
target... : prerequisites ...
command
...
...
target 即目标对象,prerequisites即相关的文件然后领取一行,以tab键开始,编写生成目标对象的编译命令
例如要生成一个main可执行文件:不依赖任何其他文件的时候,我们在linux中的shell编译命令是gcc main.c -o main
写在makefile文件中就是
main:main.c
<tab> gcc -g -c main.c -o main
//
下面将以个例子:
程序由三个c文件和三个头文件组成
file1.h file1.c file2.h file2.c include.h main.c
file1.c中定义个一个方法print1()
file2中定义一个方法print2(),该方法调用file1中的print1()方法
main。c中调用file1中的print1()和file2中的print2()
源码如下:
file1.h
//
#ifndef FILE1_H
#define FILE1_H
#endif
void print1();
///
file1.c
/
#include <stdio.h>
#include "file1.h"
void print1()
{
printf("hello 1\n");
}
//
file2.h
//
#ifndef FILE2_H
#define FILE2_H
#endif
void print2();
/
file2.c
///
#include <stdio.h>
#include "include.h"
void print2()
{
printf("function in file 2");
print1();
}
//
include.h 是包含所有头文件的文件结构
///
#ifndef INCLUDE_H
#define INCLUDE_H
#endif
#include "file1.h"
#include "file2.h"
/
main.c
#include <stdio.h>
#include "include.h"
int main(void)
{
print1();
print2();
return 0;
}
/
Makefile文件//
makefile文件
///
OBJS = main.o file1.o file2.o
main : $(OBJS)
gcc $(OBJS) -o main
main.o : main.c include.h
gcc -g -c main.c -o main.o
file1.o : file1.c file1.h
gcc -g -c file1.c -o file1.o
file2.o : file2.c include.h
gcc -g -c file2.c -o file2.o
clean :
rm main $(OBJS)
其中OBJS 是变量的定义,相当与可以替换的写法,方便多次用到!
对于c++的makefile文件也是一样的写法,关键是编译命令换成 g++!