sublime text 运行 c 程序依赖外部编译器(如 gcc/clang),需先安装并配置 path;构建系统通过 packages/user/ 下的 .sublime-build 文件定义,cmd 必须为数组格式,windows 需设 "shell": true,c++ 须用 g++/clang++ 而非 gcc,交互程序需额外处理终端保持。

Sublime Text 运行 C 程序靠的是外部编译器,不是它自己
Sublime Text 本身不带编译器,gcc 或 clang 必须已安装并能从命令行调用。如果在终端输入 gcc --version 报“command not found”,那 Sublime 肯定也跑不起来——它只是调个壳。
- Windows 用户优先装
MinGW-w64(别用老版 MinGW),安装时勾选gcc和g++,并把bin/目录加进系统PATH - macOS 用户用
brew install gcc,但注意:Xcode 自带的clang路径是/usr/bin/clang,而 Homebrew 安装的gcc默认叫gcc-13(版本号可能变),得在构建系统里写对名字 - Linux 用户一般自带
gcc,但检查下:which gcc输出是否非空;若用 Ubuntu/Debian,没装的话先sudo apt install build-essential
配置 C 构建系统:关键在 sublime-build 文件路径和字段
Sublime 的构建功能靠 .sublime-build 文件驱动,它本质是个 JSON 配置。文件必须放在 Packages/User/ 目录下(通过菜单 Preferences → Browse Packages… 打开),命名比如 C.sublime-build。
-
cmd字段要写全命令,比如["gcc", "-o", "$file_base_name", "$file"];不能漏引号,也不能写成gcc -o $file_base_name $file(字符串会被当单个参数) -
file_regex推荐用"^(..[^:]*):([0-9]+):([0-9]+):\s+(.*)$",才能双击跳转报错行;否则错误堆在底部面板里,点不动 - Windows 下需加
"shell": true,否则gcc可能找不到(尤其 MinGW-w64 安装路径含空格时) - 如果源文件名含中文或空格,
$file会自动加引号,但$file_base_name不会——输出可执行文件时建议写成"$file_base_name.exe"(Win)或"./$file_base_name"(macOS/Linux)
{
"cmd": ["gcc", "-o", "$file_base_name", "$file"],
"file_regex": "^(..[^:]*):([0-9]+):([0-9]+):\s+(.*)$",
"working_dir": "$file_path",
"selector": "source.c"
}
C++ 构建系统不能只改函数名,g++ 和链接行为有差异
把 C 的 .sublime-build 复制一份改成 C++.sublime-build,光把 gcc 换成 g++ 不够——C++ 标准库、异常、RTTI 默认开启,且 main 函数签名更严格。如果代码用了 #include <vector></vector> 却还用 gcc 编译,会报一堆 undefined reference to `std::...。
- 务必用
g++(或clang++),别指望gcc file.cpp能过 - 需要 C++17 特性?加上
"-std=c++17"参数,放cmd数组里靠前位置 - 如果项目含多个
.cpp文件,单文件构建系统没法自动编译全部;这时要么手动写g++ *.cpp -o app(不推荐),要么该用Makefile+make构建系统 - macOS 上用
g++可能链接失败(因系统默认用clang++),直接换用clang++更稳,命令一致,只需改cmd第一项
运行结果看不到?sublime-build 默认不等程序退出
写了个 printf("hello"); getchar();,按 Ctrl+B 后窗口一闪就关——因为 Sublime 的构建面板默认不保持打开,也没模拟终端交互环境。这不是代码问题,是构建配置缺了“等用户输入”或“暂停”逻辑。
立即学习“C语言免费学习笔记(深入)”;
- 简单方案:在
cmd末尾追加&& pause(Windows)或&& read(macOS/Linux),但仅限 shell 支持;此时需设"shell": true - 更可靠做法:用
exec插件或终端工具(如Terminus),让程序真正在终端里跑;sublime-build本身不适合交互式运行 - 调试阶段建议养成习惯:先确保
gcc main.c -o main && ./main在终端能跑通,再回 Sublime 配构建系统——省掉一半排查时间
最常被忽略的一点:构建系统保存后,必须关闭再重开 Sublime(或至少重启构建系统缓存),否则改了也不生效。这点没文档提,但真实发生过。










