基于VSCode+Clangd+lldb搭建Linux C++环境

为了在VSCode中使用Clangd和lldb来提供C++代码的编写、编译和调试功能,你需要进行以下步骤:

  1. 安装Visual Studio Code。
  2. 安装Clang编译器(确保Clangd可执行文件在系统PATH中)。
  3. 安装lldb(大多数Linux发行版都包含lldb包,可以通过包管理器安装)。
  4. 在VSCode中安装C/C++插件和Clangd插件。

以下是一个简单的配置示例:

.vscode/settings.json 文件:




{
    "clangd.path": "path/to/clangd",
    "clangd.arguments": [
        "--compile-commands-dir=${workspaceFolder}"
    ],
    "clangd.completion.triggerAfter": ["."]
}

tasks.json 文件:




{
    "version": "2.0.0",
    "tasks": [
        {
            "label": "build",
            "type": "shell",
            "command": "clang++",
            "args": [
                "-g",
                "${file}",
                "-o",
                "./bin/${fileBasenameNoExtension}"
            ],
            "problemMatcher": [
                "$gcc"
            ],
            "group": {
                "kind": "build",
                "isDefault": true
            }
        }
    ]
}

launch.json 文件:




{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "C/C++ Launch (lldb)",
            "type": "cppdbg",
            "request": "launch",
            "program": "${workspaceFolder}/bin/${fileBasenameNoExtension}",
            "args": [],
            "stopAtEntry": false,
            "cwd": "${workspaceFolder}",
            "environment": [],
            "externalConsole": false,
            "MIMode": "lldb",
            "preLaunchTask": "build"
        }
    ]
}

确保你的clangd可执行文件的路径正确填写在settings.json中,并且tasks.json中的编译命令与你的环境相匹配。

这样配置后,你可以在VSCode中编写C++代码,使用Clangd进行语言智能感知,并通过lldb进行调试。

最后修改于:2024年08月16日 11:22

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日