DAY20 Optimizing VS Code for C/C++ Development on Ubuntu

Optimizing VS Code for C/C++ Development on Ubuntu

This article documents an optimized Visual Studio Code setup for C and C++ development on Ubuntu 22.04.

It includes formatter integrations, IntelliSense configuration, CMake workflow improvements, UI settings, and tips for smoother embedded development.

1. Introduction

VS Code is one of the most flexible editors for C and C++ development, especially when working on Linux or embedded systems.

With the right configuration, you can achieve:

  • Fast and accurate code completion (via clangd)
  • Consistent formatting (via clang-format)
  • Better CMake integration
  • Improved navigation using ctags
  • Cleaner UI and automatic file saving
  • Support for DeviceTree, Kconfig, Makefiles, and more

This post explains each configuration section and how it improves your workflow.


2. Formatter Configuration (clang-format)

The settings configure VS Code to automatically format C/C++ files using xaver.clang-format:

json 复制代码
"[c]": {
    "editor.defaultFormatter": "xaver.clang-format"
},
"[cpp]": {
    "editor.defaultFormatter": "xaver.clang-format"
},
"editor.formatOnSave": true

Why this helps

  • Ensures consistent code style across the project
  • Avoids messy diffs when committing to Git
  • Automatically aligns braces, indentation, and spacing

You can also adjust the formatting style with:

json 复制代码
"C_Cpp.clang_format_style": "Visual Studio"

For better consistency, changing this to "LLVM" or "Google" is recommended.


3. clangd Configuration (Recommended C/C++ language server)

A custom clangd binary is used:

json 复制代码
"clangd.path": "/home/linux/clangd_14.0.3/bin/clangd",
"clangd.arguments": [
    "--log=verbose",
    "--clang-tidy",
    "--background-index",
    "--inlay-hints=false"
]

What these features do

Feature Description
--clang-tidy Static analysis and code quality checks
--background-index Builds project index silently for faster navigation
--inlay-hints=false Disables inline hint clutter
--log=verbose Useful when debugging clangd issues

You also disabled Microsoft's IntelliSense engine:

json 复制代码
"C_Cpp.intelliSenseEngine": "disabled"

This ensures that clangd is the only backend providing completions---faster and more accurate.


4. CMake Workflow Optimization

json 复制代码
"cmake.options.statusBarVisibility": "visible",
"makefile.configureOnOpen": true,
"cmake.pinnedCommands": [
    "workbench.action.tasks.configureTaskRunner",
    "workbench.action.tasks.runTask"
]

Improvements

  • CMake status bar is always visible
  • Automatically configure Makefile projects when opening
  • Quick access to commonly used build/run commands

This setup is especially helpful in embedded projects running cross-compiled toolchains.


5. UI Enhancements

The settings apply a modern UI theme:

json 复制代码
"workbench.iconTheme": "vscode-icons",
"workbench.colorTheme": "One Monokai",
"workbench.preferredDarkColorTheme": "One Dark Pro"

And a clean development font:

json 复制代码
"editor.fontFamily": "JetBrains Mono, 'Courier New', monospace",
"editor.fontLigatures": true,
"editor.fontSize": 18

Why this matters

  • Ligature fonts improve readability for syntax-heavy languages like C++
  • Larger font reduces eye strain during long development sessions
  • Icons help distinguish file types clearly

6. Hex Editor Integration

json 复制代码
"workbench.editorAssociations": {
    "*.o": "hexEditor.hexedit"
}

This is extremely useful in:

  • Embedded firmware reverse engineering
  • Reading binary logs
  • Inspecting compiled ELF sections

Additional hex editor configuration:

json 复制代码
"hexeditor.columnWidth": 16,
"hexeditor.showDecodedText": true,
"hexeditor.defaultEndianness": "little"

7. ctags Indexing

json 复制代码
"ctags.regenerateOnSave": true,
"ctags.languages": ["C", "C++", "DTS", "Kconfig", "Make"]

Why this helps

  • Ultra-fast symbol search
  • Works even when clangd analysis is not available
  • Supports DeviceTree and Linux kernel environments

8. Embedded Linux / DeviceTree Support

json 复制代码
"devicetree.bindings": [
    "/home/linux/nfs/imx6/linux-imx-rel_imx_4.1.15_2.1.0_ga_alientek/Documentation/devicetree/bindings"
]

This enables:

  • Hover hints for DTS nodes
  • Validation of DeviceTree bindings
  • Faster debugging of ARM/SoC kernel configurations

Essential for i.MX6 / ARM-based embedded work.


9. Automatic Saving

json 复制代码
"files.autoSave": "afterDelay"

Useful when switching between Vim/terminal builds and VS Code.


10. Final Thoughts

The configuration shown here turns VS Code into a powerful C/C++ IDE on Ubuntu, suitable for:

  • Embedded Linux development
  • Kernel-level C work
  • CMake-based or Makefile-based projects
  • Bare-metal or cross-compiled toolchains
  • Modern C++ projects using clangd

I

相关推荐
Book思议-20 小时前
【数据结构实战】线性表的应用
c语言·数据结构·算法·链表
real向往20 小时前
Ubuntu NVIDIA显卡驱动安装
ubuntu·安装·显卡驱动
qq_4614893320 小时前
C++与Qt图形开发
开发语言·c++·算法
Evand J21 小时前
【三维飞行器】RRT路径规划与TOA定位仿真系统,MATLAB例程,路径起终点、障碍物、TOA锚点等均可设置。附下载链接
开发语言·matlab·无人机·定位·rrt·toa·三维航迹规划
froginwe1121 小时前
Rust 异步编程
开发语言
zayzy21 小时前
前端八股总结
开发语言·前端·javascript
今天减肥吗21 小时前
前端面试题
开发语言·前端·javascript
BestOrNothing_201521 小时前
(3)Ubuntu 22.04 双系统安装全过程记录
linux·ubuntu22.04·双系统安装
码码哈哈0.021 小时前
LangChain 快速入门(从0到可用)
开发语言·python·langchain
熊文豪21 小时前
Java 入门指南
开发语言·python