C语言 _ MakeFile(一)

一、Make简介

  • 工程管理器,顾名思义,是指管理较多的文件。
  • Make工程管理器也就是个“自动编译管理器”,这里的"自动"是指它能够根据文件时间戳自动发现更新过的文件而减少编译的工作量,同时,它通过读入Makefile文件的内容来执行大量的编译工作。
  • Make将只编译改动的代码文件,而不用完全编译。

1、Makefile基本结构

  • Makefile是Make读入的唯一配置文件

           —  由make工具创建的目标提(target),通常是目标文件或可执行文件。

           —  要创建的目标所依赖的文件(dependency_file)。

           —  创建每个目标体时需要运行的命令(command)。

           —  注意:命令行前面必须是一个“TAB”键,否则编译错误为:*** missing separator.  Stop。

  • Makefile格式:

                             target :dependency_files

                               <TAB> command

  • 例子:

                             hello.o  : hello.c   hello.h

                                 gcc  -c   hello.c  -o   hello.o

2、Makefile变量

  • 一个复杂一些的例子

               sunq:kang.o  yul.o

                          gcc  kang.o  yul.o  -o  sunq

               kang.o:kang.c  kang.h

                            gcc -Wall  -O  -g  -c   kang.c   -o  kang.o

               yul.o : yul.c

                             gcc  -Wall  -O  -g  -c  yul.c  -o  yul.o

          注释:-Wall :表示允许发出gcc所有有用的报警信息。

                     -c      :只是编译不链接,生成目标文件 “.o”

                      -o file:表示把输出文件输出到file里

                 关于更多的使用man工具了解。

3、创建和使用变量

  • 创建变量的目的:
  • 用来代替一个文本字符串

        1、系列文件的名字。

        2、传递给编译器的参数。

        3、需要运行的程序。

        4、需要查找源代码的目录。

        5、需要输出信息的目录。

        6、你想要做的其他事情。

  • 优点:

                 它可以向后引用变量

  • 缺点:

                不能对该变量进行任何扩展,例如

               CFLAGS = $(CFLAGS)   -0  会造成死循环。

  • 简单方式   VAR :=var

                     m :=mm

                     x:=$(m)

                     my:=$(x)bar

                     x:=later

                     echo  $(x)$(y)  ---------   看看打印什么信息。

  • 递归展开式方式VAR=var

例子

 

 

 

          foo = $(bar)

          bar= $(ugh)

          ugh= $(bar)

          foo = Huh?

          $(foo)的值为?

          echo  $(foo)来进行查看

 

 

            — — 用这种方式定义的变量,会在变量的定义点,按照被引用的变量的当前值进行展开

            — — 这种定义变量的方式更适合再大的编程项目中使用,因为它更像我们一般的编程语言。l

例子:

          OBJS = kang.o   yul.o

          CC = gcc

          CFLAGS= -Wall  -O -g

          sunq  : $(OBJS)

                      $(CC) $(OBJS) -O sunq

          kang.o :kang.c kang.h

                       $(CC)$(CFLAGS) -c  kang.c -o kang.o

         yul.o     : yul.c  yul.h

                       $(CC)$(CFLAGS)  -c  yul.c  -o  yul.o

  • 用?=定义变量

                     dir := /foo/bar

                     FOO ?= bar

                     FOO 是?

         — —   含义是 ,如果FOO没有被定义过,那么变量FOO的值就是”bar“,如果FOO先前被定义过,那么这条语句将什么也不做,其等价于:

                         ifeq($(origin FOO),undefined)

                         FOO = bar

                         endif

  • 为变量添加值

          你可以通过+=为已定义的变量添加新的值

         例如:Main = hello.o   hello-1.o

                    Main+=hello-2.o

  • 预定义变量

           —  AR    库文件维护程序的名称,默认值为ar。AS汇编程序的名称,默认值为as。

           —  CC   C编译器的名称,默认值为cc。CPP  C编译器的名臣,默认值为$(CC)   -E

           —  CXX    C++编译器的名臣,默认值为g++。

           —  FC    FORTRAN编译器的名称,默认值为f77。

           —  RM    文件删除程序的名称,默认值为rm  -f。

 

             例子:

                     Hello :main .c  main.h

                     <tab> $(CC) -o hello  main.c

                      clean:

                     <tab> $(RM) hello             

          —  ARFLAGS      库文件维护程序的选项,无默认值

          —  ASFLAGS      汇编程序的选项,无默认值。

          —  CFLAGS         C编译器的选项,无默认值

          —  CPPFLAGS     C编译器的选项,无默认值

          —  CXXFLAGS       C++编译器的选项,无默认值

          —  FFLAGS           FORTRAN编译器的选项,无默认值

 例如:

          OBJS = kang.o   yul.o

          CC = gcc

          CFLAGS= -Wall  -O -g

          sunq  : $(OBJS)

                      $(CC) $(OBJS) -o sunq

          kang.o :kang.c kang.h

                       $(CC)$(CFLAGS) -c  kang.c -o kang.o

         yul.o     : yul.c  yul.h

                       $(CC)$(CFLAGS)  -c  yul.c  -o  yul.o

 

  • 自动变量

         —  $*          不包含扩展名的目标文件名称

         —  $+          所有的依赖文件,以空格分开,并以出现的先后为序,可以包含重复的依赖文件。

         —  $<          第一个依赖文件的名称。

         —  $?           所有时间戳比目标文件晚的依赖文件,并以空格分开

         —  $@          目标文件的完整名称

         —  $^            所有不重复的目标依赖文件,以空格分开。

         —  $%          如果目标是归档成员,则该变量表示目标的归档成员名称。

例子:

          OBJS = kang.o   yul.o

          CC = gcc

          CFLAGS= -Wall  -O -g

          sunq  : $(OBJS)

                      $(CC) $^ -o $@

          kang.o :kang.c kang.h

                       $(CC)$(CFLAGS) -c  $< -o $@

         yul.o     : yul.c  yul.h

                       $(CC)$(CFLAGS)  -c  $< -o $@

OBJS=f1.o f2.o
OBJS+=main.o
CFLAGS=-c -Wall

test.o:$(OBJS)
	gcc $(OBJS) -o test
f2.o:$<
	gcc -c -Wall f2.c -o $@
f1.o:f1.c
	gcc $(CFLAGS) f1.c -o $@
main.o:main.c
	gcc -c -Wall main.c -o main.o
.PHONY:clean
clean:
	rm *.o test

3、环境变量

  • 环境变量

        —  make在启动时会自动读取系统当前已经定义了的环境变量,并且会创建与之具有相同名称和数值的变量。

        —  如果用户在Makefile中定义 了相同名称的变量,那么用户自定的变量将会覆盖同名的环境变量。

  • Make的使用、
  • 选项

          —  -C  dir  读入指定目录下的Makefile

          —  -f   file 读入当前目录下的file文件作为Makefile

          —  -i    忽略所有的命令换行错误

          —  -I  dir 指定被包含的Makefile所在目录

          —  -n 只打印要执行的命令,但不执行这些命令。

          —  -p  显示make变量数据库和隐含规则

          —  -s  在执行命令时不显示命令

          —  -w  如果make在执行过程中改变目录,打印当前目录名。

 

  • 建立一个include 文件夹,将#include <stdio.h>放入该文件夹中

        

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Makefile 是用于自动化构建和管理 C 语言项目的常用工具。它使用文本文件来定义编译、链接和其他构建任务的规则。下面是一个简单的示例,演示了如何编写一个基本的 Makefile。 假设我们有一个包含两个源文件 main.c 和 utils.c 的项目,我们希望将它们编译为可执行文件 main。首先,我们需要创建一个名为 Makefile 的文件,并在其中添加以下内容: ```makefile # 编译器选项 CC = gcc CFLAGS = -Wall -Wextra # 目标文件 OBJS = main.o utils.o # 生成可执行文件 main: $(OBJS) $(CC) $(CFLAGS) $(OBJS) -o main # 编译每个源文件 %.o: %.c $(CC) $(CFLAGS) -c $< -o $@ # 清理生成的文件 clean: rm -f $(OBJS) main ``` 在上面的 Makefile 中,我们首先定义了编译器选项,CC 表示编译器,CFLAGS 表示编译选项。接下来,定义了目标文件 OBJS,该变量包含了所有的目标文件。 然后,定义了生成可执行文件 main 的规则。该规则指定了依赖关系,即 $(OBJS) 表示目标文件依赖于对应的源文件。在命令行中使用变量 $(CC) 和 $(CFLAGS) 来调用编译器进行链接操作。 接下来,定义了编译每个源文件的规则。使用通配符 % 表示匹配任意文件名,%.o 表示所有的目标文件依赖于对应的源文件。命令行中的 $< 代表依赖的源文件,$@ 代表目标文件。 最后,定义了一个用于清理生成文件的规则 clean。该规则使用 rm 命令删除所有目标文件和可执行文件。 要使用 Makefile,只需在命令行中运行 make 命令即可自动执行构建任务。例如,运行 make 命令将会编译源文件并生成可执行文件 main,运行 make clean 命令将会清理生成的文件。 这只是一个简单的示例,Makefile 还可以进行更多复杂的配置和任务设置,例如定义目录、库文件、头文件等。可以根据实际项目的需求对 Makefile 进行扩展和调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值