C语言 makefile学习及实现实例

时间:2022-04-12 12:58:00

C语言 makefile学习及实现实例

俗话说,不会写makefile的程序员不是好的程序员。

看了很多人写的makefile教程,感觉太难懂,还不如韦东山老师视频里讲的好理解。

先记下这几个符号,以后看到就不会忘记这是什么东西了。

先来看一个例子:

?
1
2
3
4
5
6
<span style="font-size:18px;">Person: main.o person.o  
  g++ -o $@ $^     
%.o : %.cpp
  g++ -c -o $@ $< 
clean:
  rm -rf *.o Person</span>

其中:

1、Person表示要生成的目标文件。

      main.o  person.o是依赖文件

      所以Person: main.o person.o

这句话的意思就是,要想生成Person这个文件,就要依赖于main.o , person.o这两个文件。

2、$@ : 表示目标文件,这里的目标文件就是Person
      $^   :  表示目标文件后面的所有依赖文件,也就是.o文件
      $<  :  表示第一个依赖文件,这里的第一个指的就是main.o

3、%.o : %.cpp

      %,o : %,cpp前面加%表示通配符,表示通配所有的.o文件还有所有的.cpp文件

4、还有一点要注意,上面g++前面不是空格,而是一个tab,一般情况下,tab是4个空格的大小。

5、clean: 

      对应下面的文件,如果你执行make clean,makefile就会帮你清除所有的.o和Person这个目标文件。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!