下载后直接运行安装即可,我装在: D:\msys64
安装好后,出现多个快捷方式,下表简单是介绍
快捷方式 | 描述 |
---|---|
MSYS2 CLANG64 | 使用Clang编译器的64位版本环境,提供基于LLVM的C、C++和Objective-C编译器工具链,用于生成Windows 64位原生可执行文件。 |
MSYS2 CLANGARM64 | 同样基于Clang,但针对ARM64架构(如Windows on ARM),为ARM64平台提供编译环境。 |
MSYS2 MINGW32 | 运行32位MinGW-w64工具链的命令行环境,适用于编译面向32位Windows系统的原生应用。 |
MSYS2 MINGW64 | 提供64位MinGW-w64工具链的命令行环境,主要用于编译运行在64位Windows系统上的原生应用,是常用的开发选项。我用的这个 |
MSYS2 MSYS | 基于POSIX兼容层的Shell环境,提供较为完整的Unix/Linux-like环境,支持那些需要较高程度POSIX兼容性的软件编译或脚本执行。 |
MSYS2 UCRT64 | 使用Universal CRT (UCRT) 的64位工具链环境,该环境下的工具链依赖较新的Windows SDK,可能包含对最新Windows特性和API的支持。 |
接下来的操作需要用到 pacman 命令,此表是简单的介绍,先了解一下:
命令 | 功能描述 |
---|---|
pacman -Syu | 同步并更新系统所有的软件包到最新版本(包括内核与核心库) |
pacman -S package_name | 安装指定的单个软件包及其依赖 |
pacman -S package1 package2 | 安装多个指定的软件包及它们的依赖 |
pacman -R package_name | 卸载指定的软件包,但保留其配置文件 |
pacman -Rs package_name | 卸载指定的软件包,并删除其配置文件 |
pacman -Ss search_term | 搜索软件仓库中包含指定关键词的软件包 |
pacman -Q 或 pacman -Qe | 列出已安装的所有软件包 |
pacman -Qi package_name | 查询特定软件包的详细信息 |
pacman -Qo /path/to/file | 查看指定文件属于哪个已安装的软件包 |
pacman -Scc | 清理缓存,删除所有未使用的包文件 |
pacman -Sy | 只同步软件数据库,不进行更新操作 |
pacman -Su | 更新所有已安装且有更新版本的软件包 |
pacman -Syu --noconfirm | 强制更新系统且不询问用户确认 |
# 编辑源
nano /etc/pacman.d/mirrorlist.mingw64
将清华镜像添加到开头 Server = https://mirrors.tuna.tsinghua.edu.cn/msys2/mingw/x86_64
最后 Ctrl + X
退出如有提示按 Y
保存
我是 win11 x64系统,所以我装这个版本 mingw-w64-x86_64-gcc
# 查看
pacman -Ss mingw-w64-x86_64-gcc
# 安装前,先更新数据库和软件包,确保是最新的(如果需要)
pacman -Syu
# 如果有核心包更新,会关闭 MSYS2,自己手去打开 MSYS2 后再执行一下,继续完成非核心包更新
pacman -Syu
# 安装
pacman -S mingw-w64-x86_64-gcc
安装完成后 D:\msys64\mingw64\bin
目录下就有东西了
打开 D:\msys64\mingw64\bin
目录,
在地址栏输入 cmd
打开命令行,输入命令查看版本
gcc --version
、g++ --version
将 D:\msys64\mingw64\bin
添加到环境变量。
WIN + R
打开运行窗口.。rundll32 sysdm.cpl,EditEnvironmentVariables
按 Ctrl + Shift + 回车
打开窗口。系统变量
中找到 Path
点编辑。D:\msys64\mingw64\bin
# 安装
pacman -S mingw-w64-x86_64-gdb
安装 C/C++ Extension Pack 就够了,C/C++ 扩展包
包含了在 Visual Studio Code 中进行 C++ 开发的一系列热门扩展:
demo1
用 VSCode 打开。helloworld.cpp
文件,内容:#include <iostream>
#include <string>
using namespace std;
int main()
{
cout << "Hello World" << endl;
}
因为 D:\\msys64\\mingw64\\bin\\g++.exe
、D:\\msys64\\mingw64\\bin\\gdb.exe
已经添加到环境变量。所以下面的配置中也可以改为相对路径
。
终端 > 配置默认生成任务…
完成后将自动生成 tasks.json,内容如下:(注意检查 command
、cwd
是否正确)
{
"tasks": [
{
"type": "cppbuild",
"label": "C/C++: g++.exe 生成活动文件",
"command": "D:\\msys64\\mingw64\\bin\\g++.exe",
"args": [
"-fdiagnostics-color=always",
"-g",
"${file}",
"-o",
"${fileDirname}\\${fileBasenameNoExtension}.exe"
],
"options": {
"cwd": "${fileDirname}"
},
"problemMatcher": [
"$gcc"
],
"group": {
"kind": "build",
"isDefault": true
},
"detail": "编译器: D:\\msys64\\mingw64\\bin\\g++.exe"
}
],
"version": "2.0.0"
}
我们来设置 gdb 调试
如此可自动创建 launch.json,内容如下:(注意检查miDebuggerPath
是否正确)
{
"configurations": [
{
"name": "(gdb) 启动",
"type": "cppdbg",
"request": "launch",
"program": "${fileDirname}\\${fileBasenameNoExtension}.exe",
"args": [],
"stopAtEntry": false,
"cwd": "${fileDirname}",
"environment": [],
"externalConsole": false,
"MIMode": "gdb",
"miDebuggerPath": "D:\\msys64\\mingw64\\bin\\gdb.exe",
"setupCommands": [
{
"description": "为 gdb 启用整齐打印",
"text": "-enable-pretty-printing",
"ignoreFailures": true
},
{
"description": "将反汇编风格设置为 Intel",
"text": "-gdb-set disassembly-flavor intel",
"ignoreFailures": true
}
]
}
],
"version": "2.0.0"
}
打开 helloworld.cpp
文件,按 F5
运行。
c_cpp_properties.json
用于更改编译器路径、包含路径、C++ 标准(默认为 C++17)等设置。
Ctrl + Shift + P
输入 C/C++
选择:c_cpp_properties.json
文件c_cpp_properties.json
内容:{
"configurations": [
{
"name": "g++",
"includePath": [
"${workspaceFolder}/**"
],
"defines": [
"_DEBUG",
"UNICODE",
"_UNICODE"
],
"windowsSdkVersion": "10.0.19041.0",
"compilerPath": "D:/msys64/mingw64/bin/g++.exe",
"cStandard": "c17",
"cppStandard": "c++17",
"intelliSenseMode": "windows-gcc-x64"
}
],
"version": 4
}
中国科学技术大学 http://mirrors.ustc.edu.cn/
清华大学 https://mirrors.tuna.tsinghua.edu.cn/
Using GCC with MinGW
launch.json and tasks.json 使用 ${variableName} 语法