clangd 在 Visual Studio Code 中的配置与使用教程
项目介绍
clangd 是一个基于 LLVM 的 C/C++ 语言服务器,提供了诸如自动补全、导航、错误检查和代码重构等功能。这个项目旨在提升开发者在编写 C++ 代码时的体验。vscode-clangd 是一个专为 Visual Studio Code(VSCode)设计的扩展,它使 VSCode 能通过 Language Server Protocol 无缝地集成 clangd,从而提供强大的 C/C++ 开发支持。
项目快速启动
安装必要软件
首先,确保你的系统上安装了 clangd。对于 Ubuntu 系统,你可以通过下面的命令安装:
sudo apt-get install clangd
接下来,在 VSCode 中安装 vscode-clangd 扩展:
- 打开 VSCode。
- 转到 Extensions 视图(快捷键
Ctrl+Shift+X或者点击侧边栏中的 Extensions 图标)。 - 搜索
clangd,找到由llvm-vs-code-extensions提供的vscode-clangd,然后点击 Install。
配置 clangd
安装完扩展后,可能需要进行一些基本配置以确保 VSCode 使用 clangd。在 VSCode 中按下 Ctrl + Shift + P,输入 Preferences: Open Settings (UI) 打开设置界面,或者直接编辑 settings.json 文件,添加以下配置来指定 clangd 的路径(如果默认路径未正确检测):
{
"clangd.path": "/usr/bin/clangd"
}
将 /usr/bin/clangd 替换为实际的 clangd 可执行文件路径。
启动并验证
- 打开或创建一个 C++ 文件(
.cpp或.hpp)。 - 注意 VSCode 应该不会推荐其他 C++ 扩展,且你应该能看到如智能提示、语法高亮等来自 clangd 的功能。
- 右下角状态栏应显示“clangd”字样,表明扩展已成功激活并与 clangd 连接。
应用案例和最佳实践
代码补全与导航
- 代码补全: 当输入代码时,按
Ctrl + Space强制触发补全建议。 - 跳转定义: 使用
F12或右键菜单中的 “Go to Definition” 快速跳转到函数或变量定义处。 - 查找引用: 使用
Shift + F12查找一个标识符的所有引用。
高级功能利用
- 代码重构: 对选定代码执行重构操作,例如提取变量、函数,通常可通过光标定位后使用上下文菜单中的选项。
- 诊断与修复: 错误和警告会在代码中被标记,点击灯泡图标获取修正建议。
典型生态项目
虽然 clangd 自身是 VSCode 生态的一个组成部分,但它与一系列开发工具链紧密相连,比如配合 cmake-tools 或 gcc/g++ 编译环境,可以形成一个高效的C/C++开发流程。此外,clangd 由于其遵循 Language Server Protocol,理论上可以与其他任何支持 LSP 的代码编辑器兼容,这使得它成为跨编辑器的C++开发的强大后端服务。
在使用 clangd 时,结合版本控制系统(如 Git),代码质量工具(如 clang-tidy),以及持续集成/持续部署(CI/CD)流程,可以极大地提高团队的开发效率和代码质量。
以上步骤和指导可以帮助开发者快速开始使用 clangd 和它的 VSCode 扩展,享受高效和智能化的 C/C++ 开发环境。随着熟练度的增加,探索更多高级特性和定制化配置将是进一步提升工作效率的关键。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00