Makefile文件编写-Linux-Ubuntu系统

目录

一、Makefile文件介绍

二、Makefile文件规则(格式)

1、格式

举例一:基本格式

举例二:引入变量机制

举例三:引入自动变量

举例四:多c文件编译

举例五:伪目标


一、Makefile文件介绍

两种文件名格式:Makefile、makefile

作用:Makefile是工程管理,如果编译的c文件很多,可以使用Makefile减少工作量;只需要执行一个make命令即可编译所有的c文件

make命令依赖于一个当前目录下名为Makefile的配置文件

Makefile文件会告诉make命令如何编译、如何执行

二、Makefile文件规则(格式)

1、格式

复制代码
目标:依赖

    命令        //命令前面的空余部分是一个Tab键
举例一:基本格式

在当前文件下需要有两个文件,一个是hello.c,一个是Makefile

复制代码
hello:hello.c
    gcc hello.c -o hello
**举例二:**引入变量机制

更换编译工具,引入变量机制

引用变量使用$()

复制代码
CC=gcc
hello:hello.c
    $(CC) hello.c -o hello
举例三:引入自动变量

$@ 代表所有目标

%^ 代表所有依赖

%< 代表第一个依赖

下面代码将举例二的代码使用自动变量替换

复制代码
CC=gcc
hello:hello.c
    $(CC) $^ -o $@
举例四:多c文件编译

下面有a.c,b.c,main.c,a.h,b.h几个c语言文件,若不适应Makefile文件编译,需要一个一个的使用gcc命令编译,比较麻烦:

使用Makefile文件进行多C语言文件编译:

直接在当前目录下使用make命令,即可生成可执行文件test,

举例五、多文件编译简化makefile(隐式规则)

举例四的makefile依旧有一些复杂,可以使用自动变量进行简化,如下面,第一张为之前未简化,第二张为简化后的makefile

举例六:模式规则

如下图makefile文件,使用%.o: %.c,这种模式下使用make命令可以指定仅编译哪一个.c 文件

举例七:伪目标

在当前目录下不能有和makefile目标名一样的文件,比如在makefile文件里创建一个clean目标,在当前目录下建一个名为clean的文件,再执行make clean命令就会报错

解决方法:使用伪目标来声明clean就可以避免与当前目录下的同名文件发生冲突

伪目标格式:(.PHONY:目标)

举例:之前的clean目标可以修改成这样,再执行make clean命令,尽管当前目录下有clean的同名文件,make clean命令也可以执行成功

举例八:make命令的参数

-f 参数:指定makefile,若此目录下有两个makefile文件,名字不同,可以使用-f参数指定

未完待续......

相关推荐
weixin_307779132 小时前
Jenkins jQuery3 API 插件详解:赋能插件前端开发的利器
运维·开发语言·前端·jenkins·jquery
coding record2 小时前
linux 上安装Matlab,case: Matlab2020a,或者有效时间过期
linux·运维·服务器
冉佳驹2 小时前
Linux ——— sudo权限管理和GCC编译工具链的核心操作
linux·makefile·make·gcc·sudo·.phony
海域云-罗鹏2 小时前
南昌企业服务器选择:租用与托管孰优孰劣
运维·服务器
爱跑马的程序员2 小时前
Kernel i2c 设备驱动详细讲解
linux·安卓·内核驱动
科技互联.3 小时前
企业级DevOps选型维度:制品管理与全链路安全解析
运维·安全·devops
wanhengidc3 小时前
在线服务器的功能都有哪些
运维·服务器·科技·智能手机·云计算
love混世_魔王3 小时前
VIM经典命令系列之数字递增、递减
linux·编辑器·vim·verilog vim插件·vim使用技巧·vim高效编程
PAQQ3 小时前
ubuntu 22.04 更新cmake版本
linux·运维·ubuntu