首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在makefile中使用带有自动变量的函数

是为了方便地处理文件依赖关系和自动化构建过程。自动变量是makefile中预定义的变量,它们根据当前规则的上下文自动设置其值。

在makefile中,可以使用以下自动变量来引用文件名和目标名:

  • $@:表示目标文件的名称。
  • $<:表示依赖文件列表中的第一个文件的名称。
  • $^:表示所有依赖文件的列表,以空格分隔。

在使用自动变量的函数时,可以结合这些自动变量来实现更灵活的构建过程。以下是一些常用的带有自动变量的函数:

  1. wildcard函数:用于获取指定模式的文件列表。
    • 概念:通配符函数,用于获取符合指定模式的文件列表。
    • 优势:方便快捷地获取文件列表。
    • 应用场景:在构建过程中需要处理多个文件时,可以使用wildcard函数获取文件列表。
    • 腾讯云相关产品:无

示例:

代码语言:txt
复制

SRC_FILES := $(wildcard src/*.c)

OBJ_FILES := $(patsubst src/%.c, obj/%.o, $(SRC_FILES))

代码语言:txt
复制
  1. patsubst函数:用于替换指定模式的字符串。
    • 概念:模式替换函数,用于将符合指定模式的字符串替换为指定的字符串。
    • 优势:方便地进行字符串替换操作。
    • 应用场景:在构建过程中需要对文件名进行替换时,可以使用patsubst函数。
    • 腾讯云相关产品:无

示例:

代码语言:txt
复制

OBJ_FILES := $(patsubst src/%.c, obj/%.o, $(SRC_FILES))

代码语言:txt
复制
  1. dir函数:用于获取文件所在目录的路径。
    • 概念:目录函数,用于获取指定文件的所在目录路径。
    • 优势:方便获取文件所在目录的路径。
    • 应用场景:在构建过程中需要获取文件所在目录的路径时,可以使用dir函数。
    • 腾讯云相关产品:无

示例:

代码语言:txt
复制

OBJ_DIR := $(dir $(OBJ_FILES))

代码语言:txt
复制
  1. notdir函数:用于获取文件名部分。
    • 概念:文件名函数,用于获取指定文件的文件名部分。
    • 优势:方便获取文件名部分。
    • 应用场景:在构建过程中需要获取文件名部分时,可以使用notdir函数。
    • 腾讯云相关产品:无

示例:

代码语言:txt
复制

OBJ_NAMES := $(notdir $(OBJ_FILES))

代码语言:txt
复制
  1. subst函数:用于替换字符串。
    • 概念:字符串替换函数,用于将指定字符串替换为另一个字符串。
    • 优势:方便进行字符串替换操作。
    • 应用场景:在构建过程中需要对字符串进行替换时,可以使用subst函数。
    • 腾讯云相关产品:无

示例:

代码语言:txt
复制

SRC_FILES := $(subst .c,.o,$(SRC_FILES))

代码语言:txt
复制

这些带有自动变量的函数可以在makefile中灵活使用,以实现更高效和便捷的构建过程。请根据具体的项目需求选择适合的函数来处理文件依赖关系和构建过程。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Makefile经典教程(掌握这些足够)

    makefile很重要       什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makefile还是要懂。这就好像现在有这么多的HTML的编辑器,但如果你想成为一个专业人士,你还是要了解HTML的标识的含义。特别在Unix下的软件编译,你就不能不自己写makefile了,会不会写makefile,从一个侧面说明了一个人是否具备完成大型工程的能力。因为,makefile关系到了整个工程的编译规则。一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令。makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。

    02

    什么是makefile(3)

    六、另类风格的makefile 即然我们的make可以自动推导命令,那么我看到那堆[.o]和[.h]的依赖就有点不爽,那么多的重复的[.h],能不能把其收拢起来,好吧,没有问题,这个对于make来说很容易,谁叫它提供了自动推导命令和文件的功能呢?来看看最新风格的makefile吧。 objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o edit : $(objects) cc -o edit $(objects) $(objects) : defs.h kbd.o command.o files.o : command.h display.o insert.o search.o files.o : buffer.h .PHONY : clean clean : rm edit $(objects) 这种风格,让我们的makefile变得很简单,但我们的文件依赖关系就显得有点凌乱了。鱼和熊掌不可兼得。还看你的喜好了。我是不喜欢这种风格的,一是文件的依赖关系看不清楚,二是如果文件一多,要加入几个新的.o文件,那就理不清楚了。

    02
    领券