0

0

C++初学者在MacOS上搭建C++环境教程

P粉602998670

P粉602998670

发布时间:2025-09-07 10:28:01

|

1014人浏览过

|

来源于php中文网

原创

首先安装Xcode命令行工具获取Clang编译器,再安装Homebrew以便管理开发工具,最后配置Visual Studio Code及其C++扩展,即可在macOS上完成C++开发环境搭建并运行调试程序。

c++初学者在macos上搭建c++环境教程

macOS上为C++初学者搭建开发环境,最直接的路径是:先安装Xcode命令行工具,这会给你带来Clang编译器和基础的构建工具。接着,强烈建议安装Homebrew这个包管理器,它能让后续安装其他工具(比如CMake、甚至是GNU工具链)变得异常简单。最后,选择一个适合的集成开发环境(IDE)或代码编辑器,比如Visual Studio Code,并配置好它的C++扩展,你就可以开始编写和编译C++代码了。

解决方案

搭建C++环境的过程其实没那么复杂,我们可以一步步来。

  1. 安装Xcode命令行工具(Command Line Tools) 这是macOS上C++开发的基础。它包含了Clang编译器、Make工具以及其他一些Unix工具。 打开“终端”(Terminal.app),输入以下命令:

    xcode-select --install
    系统会弹出一个窗口,提示你安装。点击“安装”并同意许可协议即可。这个过程可能需要一些时间,取决于你的网络速度。 安装完成后,你可以通过输入
    clang --version
    来验证Clang编译器是否成功安装。如果看到版本信息,那就说明第一步成功了。

  2. 安装Homebrew(可选,但强烈推荐) Homebrew是macOS上一个非常棒的包管理器,它能让你轻松安装那些Apple没有预装的、或者更新版本的开发工具和库。对于C++开发来说,它简直是神器。 在终端中输入以下命令来安装Homebrew:

    /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
    按照终端的提示操作,可能需要你输入macOS的用户密码。安装完成后,它会提示你将Homebrew添加到
    PATH
    环境变量中,通常会给出一两行命令,比如
    echo 'eval "$(/opt/homebrew/bin/brew shellenv)"' >> ~/.zprofile
    (如果你是M系列芯片)或者
    ~/.bash_profile
    (如果你是Intel芯片)。照着做就行,然后
    source ~/.zprofile
    source ~/.bash_profile
    让配置生效。 验证Homebrew是否安装成功:
    brew --version

  3. 选择并配置集成开发环境(IDE)或代码编辑器 对于C++初学者,我个人最推荐Visual Studio Code (VS Code)。它轻量、免费、功能强大,并且有非常活跃的社区支持。

    • 安装VS Code: 你可以从VS Code官网下载安装包,拖到“应用程序”文件夹。 或者,如果你安装了Homebrew,可以直接通过以下命令安装:

      brew install --cask visual-studio-code

    • 安装C/C++扩展: 打开VS Code,点击左侧的“扩展”图标(或按

      Cmd+Shift+X
      )。 在搜索框中输入“C/C++”,找到由Microsoft提供的“C/C++ Extension Pack”并安装它。这个扩展包会安装几个核心的C++开发相关扩展,包括语法高亮、智能感知、调试支持等。

    • 编写你的第一个C++程序: 在VS Code中新建一个文件,保存为

      hello.cpp
      。 输入以下代码:

      #include 
      
      int main() {
          std::cout << "Hello, C++ on macOS!" << std::endl;
          return 0;
      }

      现在,你可以在终端中手动编译和运行它:

      clang++ hello.cpp -o hello
      ./hello
      你应该会看到输出“Hello, C++ on macOS!”。

macOS上C++环境搭建为何显得“特别”?

说实话,初次在macOS上接触C++环境搭建,可能会觉得它和你在网上看到的Windows或Linux教程有点不一样,甚至有点“拧巴”。这主要是因为macOS虽然基于Unix,但它有自己一套独特的设计哲学和工具链。

首先,macOS的默认编译器是Clang,而不是GCC。虽然Clang在绝大多数情况下都与GCC兼容,甚至在某些方面(比如编译速度和诊断信息)做得更好,但对于习惯了GCC的用户来说,这可能需要一点适应。例如,你可能会在教程里看到

g++
命令,但在macOS上,
g++
往往只是
clang++
的一个符号链接。这本身不是问题,但如果你需要特定的GCC版本或GCC独有的扩展,就得通过Homebrew单独安装。

立即学习C++免费学习笔记(深入)”;

其次,调试器也是一个点。macOS默认的调试器是LLDB,而不是Linux上常见的GDB。LLDB与Clang配合得非常好,是现代且功能强大的调试器。不过,如果你之前用GDB比较多,习惯了它的命令和工作流,切换到LLDB可能需要一些学习曲线。虽然Homebrew可以安装GDB,但在macOS上使用GDB需要额外的代码签名步骤,这对于初学者来说是相当麻烦且容易出错的。我个人建议,既然在macOS上,就拥抱LLDB吧,它真的不赖。

再来,就是macOS的系统安全机制。像Gatekeeper、系统完整性保护(SIP)等,有时候会让你在安装或运行某些非官方来源的开发工具时遇到阻碍。这不是坏事,但确实可能让一些命令行操作变得没那么“丝滑”。不过,Homebrew作为社区公认的解决方案,很大程度上缓解了这些问题。它能帮你把各种工具以一种符合macOS规范的方式安装好,省去了很多折腾。

除了VS Code,还有哪些IDE或编辑器适合C++初学者?

VS Code固然是我的首选推荐,但它毕竟只是一个高度可配置的代码编辑器,对于某些追求“开箱即用”或更集成体验的初学者来说,可能还有其他选择。

  • Xcode: 如果你已经安装了Xcode(完整的IDE,不仅仅是命令行工具),或者未来计划涉足iOS/macOS应用开发,那么Xcode本身就是一个非常强大的C++ IDE。它提供了完整的项目管理、图形化调试界面和性能分析工具。对于C++初学者来说,Xcode的项目模板和构建系统(基于CMake或自定义构建脚本)可能比VS Code的

    tasks.json
    launch.json
    更容易上手,因为它把很多底层细节都封装好了。缺点是它比较庞大,启动速度相对慢,而且如果你只写纯C++控制台程序,它的很多功能可能显得有些多余。

  • CLion: 这是JetBrains出品的一款商业IDE,但它的C++支持是顶级的。CLion的智能感知、代码重构、内置调试器集成以及对CMake的完美支持,都让C++开发体验达到了极致。对于初学者来说,CLion的优点在于它能极大地降低配置的复杂性,很多东西它都帮你处理好了,你只需要专注于代码。缺点是它是付费软件,不过JetBrains为学生提供了免费授权,如果你是学生,这是个非常值得考虑的选择。

    Peachly AI
    Peachly AI

    Peachly AI是一个一体化的AI广告解决方案,帮助企业创建、定位和优化他们的广告活动。

    下载
  • Atom / Sublime Text: 这两款是更偏向于“文本编辑器”的工具,但通过安装丰富的插件,它们也能摇身一变成为功能强大的C++开发环境。它们的优点是轻量、启动快、高度可定制。但对于C++初学者来说,可能需要花费更多时间去配置编译、运行和调试的环境,这比VS Code或Xcode/CLion要复杂一些。如果你喜欢折腾,或者未来想尝试更极客的开发方式,可以试试。

选择哪个,很大程度上取决于你的个人偏好和学习风格。没有绝对的“最好”,只有最适合你的。

如何在VS Code中配置C++的编译和调试?

在VS Code里写C++,最关键的一步就是让它知道怎么编译你的代码,以及怎么启动调试器。这通常通过配置

tasks.json
launch.json
这两个文件来完成。别担心,VS Code的C/C++扩展会帮你生成这些文件的基础模板,我们只需要稍作修改。

  1. 生成配置模板: 打开你的C++项目文件夹(或者包含

    hello.cpp
    的文件夹)。 在VS Code中,按下
    Cmd+Shift+P
    打开命令面板。 输入“C/C++: Edit Configurations (UI)”并选择它。这会打开一个图形界面,你可以配置编译器路径等。通常,默认的Clang配置就够用了。 接着,再次按下
    Cmd+Shift+P
    ,输入“Tasks: Configure Default Build Task”并选择它。然后选择“Create tasks.json file from template”,再选择“C/C++: clang++ build active file”。这会生成一个
    tasks.json
    文件。 最后,按下
    Cmd+Shift+P
    ,输入“Run and Debug”,然后点击“create a launch.json file”,选择“C++ (GDB/LLDB)”。这会生成一个
    launch.json
    文件。

  2. 理解和修改

    tasks.json
    (编译配置):
    tasks.json
    文件告诉VS Code如何编译你的C++代码。一个典型的配置可能看起来像这样:

    {
        "version": "2.0.0",
        "tasks": [
            {
                "label": "build current file", // 任务名称,可以自定义
                "type": "shell",
                "command": "clang++",         // 使用clang++编译器
                "args": [
                    "-std=c++17",             // 指定C++标准,例如C++17,也可以是c++11, c++14, c++20
                    "-g",                     // 编译时加入调试信息,非常重要!
                    "${file}",                // 当前打开的文件
                    "-o",
                    "${fileDirname}/${fileBasenameNoExtension}" // 输出的可执行文件路径和名称
                ],
                "group": {
                    "kind": "build",
                    "isDefault": true         // 设置为默认构建任务
                },
                "problemMatcher": [
                    "$clang"                  // 使用clang的问题匹配器,用于解析编译错误
                ],
                "detail": "使用clang++编译当前C++文件"
            }
        ]
    }

    这里有几个关键点:

    • "command": "clang++"
      :确保VS Code调用的是Clang编译器。
    • "-std=c++17"
      :根据你的需求调整C++标准。
    • "-g"
      这个参数至关重要!它告诉编译器在生成可执行文件时包含调试信息。如果没有这个,调试器就无法知道你的代码行号、变量值等信息。
    • "${fileDirname}/${fileBasenameNoExtension}"
      :这是一个VS Code的变量,表示将可执行文件输出到当前文件所在的目录,并且文件名与源文件同名(不含扩展名)。
    • "isDefault": true
      :当你按下
      Cmd+Shift+B
      时,VS Code就会执行这个任务。
  3. 理解和修改

    launch.json
    (调试配置):
    launch.json
    文件告诉VS Code如何启动你的程序并附加调试器。对于macOS,我们通常使用
    lldb

    {
        "version": "0.2.0",
        "configurations": [
            {
                "name": "(lldb) Launch",
                "type": "cppdbg",
                "request": "launch",
                "program": "${fileDirname}/${fileBasenameNoExtension}", // 要运行的可执行文件
                "args": [],                                            // 命令行参数
                "stopAtEntry": false,                                  // 是否在程序入口处停止
                "cwd": "${workspaceFolder}",                           // 程序工作目录
                "environment": [],
                "externalConsole": false,                              // 是否使用外部终端运行
                "MIMode": "lldb",                                      // 指定调试器为lldb
                "preLaunchTask": "build current file"                  // 在调试前先执行的构建任务
            }
        ]
    }

    这里最重要的几点:

    • "program": "${fileDirname}/${fileBasenameNoExtension}"
      :确保这里指向的是你的编译产物(可执行文件)。
    • "MIMode": "lldb"
      :明确指定使用LLDB作为调试器。
    • "preLaunchTask": "build current file"
      :这个配置非常关键。它告诉VS Code,在启动调试之前,先去执行我们刚才在
      tasks.json
      中定义的名为“build current file”的任务。这样就能确保你调试的是最新编译的代码。

配置完成后,你就可以在VS Code中打开你的C++文件,设置断点,然后点击左侧的“运行和调试”图标(或按

Cmd+Shift+D
),选择“ (lldb) Launch ”配置,然后点击绿色的播放按钮,就可以开始愉快的调试了。如果一切顺利,你会看到程序在断点处暂停,并且可以检查变量值、单步执行代码。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

403

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

307

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

424

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

172

2023.10.30

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

219

2023.12.07

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

521

2023.07.26

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.4万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号