编写包含多文件的Makefile以及Makefile的嵌套实验

(1)创建目录结构

(2)输入"tree"命令,查看目录;若没有则安装tree命令 (sudo apt-get install tree )


//f1.c

#include "../include/myinclude.h"                                                                            
void print1()
{
    printf("Message f1.c\n");
    return;
}

//Makefile (/f1目录下的)

../$(OBJS_DIR)/f1.o:f1.c                                                                                     
    $(CC) -c $^ -o $@
f2.c 和f2目录下的Makefle和f1目录下的除名字外内容相同

//main.c 

#include <stdio.h>                                                                                           
int main()
{
    print1();
    print2();

    return 0;
}
//Makefile (/man目录下的Makefile)

../$(OBJS_DIR)/main.o:main.c                                                                                 
    $(CC) -c $^ -o $@

//顶层目录下的Makeflie文件
cc=gcc                                                                                                       
SUBDIRS=f1 \
        f2 \
        main \
        obj
OBJS=f1.o f2.o main.o
BIN=myapp
OBJS_DIR=obj
BIN_DIR=bin
export CC OBJS BIN OBJS_DIR BIN_DIR

all:CHECK_DIR $(SUBDIRS)
CHECK_DIR:
    mkdir -p $(BIN_DIR)
$(SUBDIRS):ECHO
    make -C $@
ECHO:
    @echo $(SUBDIRS)
    @echo begin compile
CLEAN:
    @$(RM) $(OBJS_DIR)/*.o
    @rm -rf $(BIN_DIR)
//Obj目录下的Makefile

../$(BIN_DIR)/$(BIN):$(OBJS)                                                                                 
    $(CC) -o $@ $^
include目录下的myinclude.h 文件
#include <stdio.h> 
显示效果:








  • 1
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
文件编译是指将一个大的程序分成多个小的模块,每个模块独立完成一部分功能,然后再将它们合并起来。在 C++ 中,每个模块通常对应一个 .cpp 文件,其中包含了该模块的实现代码,以及一个 .h 文件,其中包含了该模块的声明和定义。 makefile 是一种用来自动化编译程序的工具,可以根据源代码的依赖关系,自动地编译出可执行程序。下面是一个简单的 makefile 示例,假设我们有两个源代码文件 main.cpp 和 func.cpp,分别对应主函数和某个函数的实现。 ```makefile CC = g++ CFLAGS = -Wall -g OBJS = main.o func.o all: program program: $(OBJS) $(CC) $(CFLAGS) -o program $(OBJS) main.o: main.cpp func.h $(CC) $(CFLAGS) -c main.cpp func.o: func.cpp func.h $(CC) $(CFLAGS) -c func.cpp clean: rm -f program *.o ``` 上面的 makefile 分为三个部分: - 变量定义:定义了编译器和编译选项,以及目标文件的名字。 - 目标声明:声明了要生成的目标文件 program,以及它依赖的源代码文件。 - 规则定义:定义了每个源代码文件的编译规则,以及如何生成目标文件。 其中,变量定义部分可以根据实际情况进行修改。目标声明部分需要根据实际的源代码文件进行修改。规则定义部分则是最关键的部分,它定义了如何将源代码文件编译成目标文件,以及如何将多个目标文件链接成可执行程序。 在上面的示例中,我们使用了变量 $(CC) 和 $(CFLAGS),它们分别表示编译器和编译选项。变量 $(OBJS) 则表示所有的目标文件,即 main.o 和 func.o。目标声明部分定义了一个名为 program 的目标文件,它依赖于 main.o 和 func.o 两个源代码文件。规则定义部分则使用了两个模式规则,分别定义了如何将 main.cpp 和 func.cpp 编译成目标文件。 最后,在命令行中执行 make 命令即可自动编译生成可执行程序。如果需要清除生成的文件,可以执行 make clean 命令。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值