Windows 下使用 Mingw32-make 来执行 Makefile示例[通俗易懂]

https://cloud.tencent.com/developer/article/2055156

大家好,又见面了,我是你们的朋友全栈君。

文章目录

先下载 Mingw

这里使用的是 mingw32 不是 64 的,需要 64位 的自行搜索下载

32位 的可以参考我之前一篇的:C – Book Note – Win 开发环境设置


设置好环境变量

如下图设置,我是安装在:C:\MinGW 下的

在这里插入图片描述

在这里插入图片描述


确认安装环境状态


gcc

在 cmd 或是 ps(power shell) 中输入:gcc -v,出现下面类似的输出,就OK了,如果不行,就要确认一下环境变量是否设置好了 Mingw 的 bin 目录

在这里插入图片描述

在这里插入图片描述


mingw32-make

同样看看 mingw32-make 能否正常执行,输出类似一下信息就 OK 了

在这里插入图片描述

在这里插入图片描述

但是名字太长,还有个”-“号,不方便输入

我们将 mingw32-make.exe 复制出一份,并且改名为:make.exe,这样后续命令行中 make 就方便多了

在这里插入图片描述

在这里插入图片描述

再次测试一下:make,可以看到一样的输出信息

在这里插入图片描述

在这里插入图片描述


C 工程测试

准备好一下几个源码文件


main.c

代码语言:javascript

复制

// author : jave.lin
// file : main.c
#include <stdio.h>
extern void call_math();
int main() { 
   
    call_math();
    return 0;
}

math.c

代码语言:javascript

复制

#ifndef _MATH__C_
#define _MATH__C_
// author : jave.lin
// file : math.c
int add(int a, int b) { 
   
    return a + b;
}
int sub(int a, int b) { 
   
    return a - b;
}
int mul(int a, int b) { 
   
    return a * b;
}
int div(int a, int b) { 
   
    return a / b;
}
#endif

call_math.c

代码语言:javascript

复制

#ifndef _CALL_MATH__C_
#define _CALL_MATH__C_
// author : jave.lin
// file : call_math.c
#include <stdio.h>
extern int add(int, int);
extern int sub(int, int);
extern int mul(int, int);
extern int div(int, int);
void call_math() { 
   
    int a = 8, b = 2;
    printf("a = %d, b = %d\n", a, b);
    printf("add(a:%d, b:%d) = %d\n", a, b, add(a, b));
    printf("sub(a:%d, b:%d) = %d\n", a, b, sub(a, b));
    printf("mul(a:%d, b:%d) = %d\n", a, b, mul(a, b));
    printf("div(a:%d, b:%d) = %d\n", a, b, div(a, b));
}
#endif

准备好 Makefile 文件

代码语言:javascript

复制

# author : jave.lin
# file : Makefile
main : main.o math.o call_math.o
	gcc main.o math.o call_math.o -o main

main.o : main.c
	gcc main.c -c -o main.o

math.o : math.c
	gcc math.c -c -o math.o

call_math.o : call_math.c
	gcc call_math.c -c -o call_math.o


.PHONY : clean
clean:
	rm *.o main.exe -rf

执行 Makefile

将 shell 当前目录定位在我们的 Makefile 所在目录下(方便一个 make 就搞定,这样就不用输入其他的目录信息)


执行前

在这里插入图片描述

在这里插入图片描述


执行后

在这里插入图片描述

在这里插入图片描述


运行 main.exe

在这里插入图片描述

在这里插入图片描述


执行 Makefile clean 清理文件


执行前

在这里插入图片描述

在这里插入图片描述


执行后

在这里插入图片描述

在这里插入图片描述


整体运行演示 GIF

在这里插入图片描述

使用 `mingw32-make` 构建项目时,遇到 `error: missing separator` 错误通常与 `Makefile` 文件中的语法问题有关。该错误表明 `make` 在解析 `Makefile` 时未能识别到正确的命令分隔符(Tab 字符),这是由于 `Makefile` 中的规则命令部分未使用 Tab 缩进导致的。 ### 常见原因及修复方法 1. **缩进错误** 在 `Makefile` 中,每个命令行必须以 **Tab 字符** 开头,不能使用空格替代。如果在规则后使用了空格缩进,`make` 会报错 `missing separator`。 ```makefile target: command # 正确:以 Tab 开头 command # 错误:以空格开头 ``` **修复方法**:确保所有命令行前使用 Tab 而非空格。 2. **编辑器自动替换 Tab 为空格** 某些文本编辑器(如 VS Code、Sublime Text)默认将 Tab 替换为多个空格。这会导致 `Makefile` 中的命令行看起来缩进正确,但实际未使用真正的 Tab 字符。 **修复方法**:在编辑器中禁用 "Tab 转换为空格" 功能,确保 `Makefile` 中的缩进使用的是原始 Tab 字符。 3. **Makefile 中混用空格与 Tab** 如果 `Makefile` 中变量赋值或规则定义部分混用了空格和 Tab,也可能导致解析错误。 **修复方法**:检查 `Makefile` 中所有命令行前的缩进是否一致,并确保使用的是 Tab。 4. **特殊字符或隐藏符号** 有时从网页复制 `Makefile` 内容时,可能会引入不可见的特殊字符(如全角 Tab 或 Unicode 缩进字符),这些字符 `make` 无法识别。 **修复方法**:手动删除缩进并重新使用 Tab 键输入,或使用支持显示不可见字符的编辑器进行清理。 5. **Makefile.Release 文件特定问题** 由于错误提示中提到 `Makefile.Release:69`,说明问题出现在 Release 构建配置的 `Makefile` 文件第 69 行。该文件可能是由构建系统(如 Qt 的 qmake)自动生成的。 **修复方法**: - 检查原始 `.pro` 文件或构建配置是否正确。 - 清理构建目录并重新生成 `Makefile`。 - 如果手动修改了 `Makefile.Release`,建议恢复为自动生成的版本。 --- ### 示例修复 假设 `Makefile.Release` 第 69 行内容如下: ```makefile $(TARGET): $(OBJECTS) $(OBJCXX) -o $(TARGET) $(OBJECTS) $(LIBS) ``` 该行缺少了正确的命令前缀(Tab),应修改为: ```makefile $(TARGET): $(OBJECTS) $(OBJCXX) -o $(TARGET) $(OBJECTS) $(LIBS) ``` --- ### 验证方式 1. 使用 `cat -A Makefile.Release` 命令查看隐藏字符,Tab 会显示为 `^I`,空格则不会。 2. 使用 `make -n` 命令进行干运行,查看 `make` 是否能正确解析所有规则。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值