C++代码格式化-clang-format

news2025/3/1 14:12:54

文章目录

    • 前言
    • c++|vscode|clang-format
    • c++|vs|clang-format
    • c++|.clang-format
    • 其他
    • 附录
      • `Visual Studio`格式在vs和vscode中不同
      • 无法从繁体切换到简体
    • 我的vs code配置

前言

一个项目中的代码,可能来自不同的地方。不管是多人合作,还是ctrl-c/ctrl-v,都有可能出现代码风格的不一致。关于代码风格的介绍,可以参考:Google 开源项目风格指南——中文版 — Google 开源项目风格指南

因为我平常基本使用C++,所以本文侧重于,找出一个使得C++代码风格一致的方法。方法需要满足下面需求:

  • 平台无关:C++的功能代码可能需要运行在不同平台,如window和linux。所以,统一风格的方法,不能受平台限制。

  • 与软件无强相关。不同的人可能使用不同的编辑器。如vs code,vs,vim等。所以,统一风格的方法,不能和软件强行绑定。

  • 便捷性。项目中的其他人可以方便的使用。这点主要时看配置能否导出,导出后可以无缝使用。

C++中,我目前尝试过的有 EditorConfig Specification和ClangFormat documentation。

首先是EditorConfig,它支持的格式很少。vscode的EditorConfig插件,只支持Supported Pairs。如果需要这样的设置,比如,函数的大括号换行,函数内部的大括号不换行,则做不到。

ClangFormat我试用了,还不错。它支持C/C++/Java/JavaScript/JSON/Objective-C/Protobuf/C#代码的格式化。支持集成到Visual Studio CodeVisualStudio

项目记录下格式代码的具体操作。


c++|vscode|clang-format

需要先安装下插件:C++ programming with Visual Studio Code

如果是在图形界面中配置,可以下面这样填写。C_Cpp: Clang_format_fallback Style中,选填非Visual Studio的选项即可,比如LLVM,google等。我这里选的是googleC_Cpp: Clang_format_style中选填file,表示如果存在.clang-format文件,优先使用 .clang-format中的配置。(至于为什么不能选Visual Studio,因为它在vs和vscode中有点不一样,见附录。)

在这里插入图片描述

但我更喜欢直接修改vscode的配置文件。打开配置文件的方式见:vscode的配置文件setting.json的UI界面或者json形式_vscode josn和ui_Gabriel_wei的博客-CSDN博客

添加下面这样的内容:代码自动保存,保存时自动进行格式化。

// 控制自动保存脏编辑器。有关自动保存的详细信息,请参阅[此处](https://code.visualstudio.com/docs/editor/codebasics#_save-auto-save)。
	//  - off: 脏编辑器永远不会自动保存。
	//  - afterDelay: 将在配置的 "#files.autoSaveDelay#" 后自动保存脏编辑器。
	//  - onFocusChange: 当编辑器失去焦点时,将自动保存脏编辑器。
	//  - onWindowChange: 当窗口失去焦点时,将自动保存脏编辑器。
	"files.autoSave": "onFocusChange",
	// 保存是格式化
	"editor.formatOnSave": true,
	"C_Cpp.clang_format_fallbackStyle": "Google",

c++|vs|clang-format

保存则进行format,需要安装下插件:Format document on Save

选项这里选择,和vscode中保持一致。避免使用不同软件打开,导致使用不同的format。这里,同上,选择google

在这里插入图片描述


c++|.clang-format

如果需要微调默认google的style,或者需要导出.clang-format文件,以直接放在项目中。该咋整。

可以运行下面命令导出,更多clang-format命令的使用,见Clang-Format Style Options — Clang 17.0.0git documentation

clang-format -style=llvm -dump-config > .clang-format

如果自己不想导出,想大概找个,网上也有人导出:GitHub - kehanXue/google-style-clang-format: A .clang-format file for Google C++ Style.、clang-format styles · GitHub


其他

  • 前端的代码格式化:代码洁癖养成指南 · Ifyour’s Blog - ESLint + Prettier

附录

Visual Studio格式在vs和vscode中不同

vscode1.76.1中将样式设置为Visual Studio。

在这里插入图片描述

vs16.11.21中将样式设置为Visual Studio。

在这里插入图片描述

但这两者之间的样式略有区别。在引号和指针的位置上略有不同。

// vs code中对引用的格式化
NTSTATUS add_rule(rule_t &rule)


// vs中对引用的格式化
NTSTATUS add_rule(rule_t& rule)

至于为啥不一样,我不知道。因为,我没有找到这两个的clant-format配置。


无法从繁体切换到简体

windows上,vs安装插件的过程中,可能遇到繁体字和简体字切换的问题。可能是因为快捷键是ctrl+shif+f的原因。这里重写选择下简体中文即可。

在这里插入图片描述


我的vs code配置

不同时期,敲不同语言的代码,所以安装过一些杂七杂八的插件。

目前以C++为主。清理下配置文件,还有这些。

{
	// 是否在集成终端中运行代码。
	"code-runner.runInTerminal": true,
	// 控制资源管理器是否在把文件删除到废纸篓时进行确认。
	"explorer.confirmDelete": false,
	// 启用 Tab 补全。
	//  - on: 在按下 Tab 键时进行 Tab 补全,将插入最佳匹配建议。
	//  - off: 禁用 Tab 补全。
	//  - onlySnippets: 在前缀匹配时进行 Tab 补全。在 "quickSuggestions" 未启用时体验最好。
	"editor.tabCompletion": "on",
	// Set default browser
	"open-in-browser.default": "chrome",
	// 控制是否在键入时自动显示建议。
	"editor.quickSuggestions": {
		"other": true,
		"comments": true,
		"strings": true
	},
	// 设置字体大小
	"editor.fontSize": 20,
	"editor.renderWhitespace": "none",
	// 搜索文件的时候,.ignore中的文件也搜索
	"search.useIgnoreFiles": false,
	"[python]": {
		"editor.formatOnType": true
	},
	// 控制自动保存脏编辑器。有关自动保存的详细信息,请参阅[此处](https://code.visualstudio.com/docs/editor/codebasics#_save-auto-save)。
	//  - off: 脏编辑器永远不会自动保存。
	//  - afterDelay: 将在配置的 "#files.autoSaveDelay#" 后自动保存脏编辑器。
	//  - onFocusChange: 当编辑器失去焦点时,将自动保存脏编辑器。
	//  - onWindowChange: 当窗口失去焦点时,将自动保存脏编辑器。
	"files.autoSave": "onFocusChange",
	// 保存是格式化
	"editor.formatOnSave": true,
	"C_Cpp.clang_format_fallbackStyle": "Google",
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/404808.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

剑指offer JZ6 从尾到头打印链表

Java 剑指offer JZ6 从尾到头打印链表 文章目录Java 剑指offer JZ6 从尾到头打印链表一、题目描述二、递归写法三、栈方法使用Java的递归和栈解决从尾到头打印链表的问题 一、题目描述 输入一个链表的头节点,按链表从尾到头的顺序返回每个节点的值(用数组…

spring cloud @RefreshScope 刷新机制

在学习 nacos 的配置修改发现用到了 RefreshScope 注解,将 spring boot 的日志调整如下logging:level:com:alibaba:cloud: debugorg:springframework:context: debugcloud: debug调用 nacos 的配置修改,看到如下信息2023-03-10 15:48:15.332 INFO [com.a…

三天吃透MySQL面试八股文

本文已经收录到Github仓库,该仓库包含计算机基础、Java基础、多线程、JVM、数据库、Redis、Spring、Mybatis、SpringMVC、SpringBoot、分布式、微服务、设计模式、架构、校招社招分享等核心知识点,欢迎star~ Github地址:https://github.com/…

MGRE综合实验

实验拓扑及相关要求: IP地址配置: ip规划如该拓扑上可视 缺省路由: [r1]ip route-static 0.0.0.0 0 15.0.0.2 [r2]ip route-static 0.0.0.0 0 25.0.0.2 [r3]ip route-static 0.0.0.0 0 35.0.0.2 [r4]ip route-static 0.0.0.0 0 45.0.0.2 公…

Java的二叉树、红黑树、B+树

数组和链表是常用的数据结构,数组虽然查找快(有序数组可以通过二分法查找),但是插入和删除是比较慢的;而链表,插入和删除很快(只需要改变一些引用值),但是查找就很慢&…

游戏引擎开发总结:序列化系统

序列化需要准备什么?首先,我们需要一个被序列化类实现序列化函数,以及序列化库。准备我的序列化库是Yaml-cpp,序列话函数就命名为Serialize,另外我们不需要关心组件类型是具体是什么,所以我这边使用多态&am…

Spring和MaBatis整合

Spring和MyBatis整合: 先瞅一眼各种文件路径: 将之前mybatis中的测试类中的SqlSessionFactory(通过其openSession()来获得对象SqlSession),和Mybatis配置文件中的数据源(url,username等&#…

【Java爬虫】HttpClient+Jsoup实现爬取校内新闻

警告网络爬虫作为一门技术,在使用过程中,应该遵守Robots协议。采集数据时应注意礼貌,不允许爬的网站尽量不要短时间大频率爬取,涉及hdd的网站更是不要去满足自己的好奇心,不然说不准哪天就和吴签一起吃大碗宽面了...介…

[洛谷-P2585][ZJOI2006]三色二叉树(树形DP+状态机DP)

[洛谷-P2585][ZJOI2006]三色二叉树(树形DP状态机DP)一、题目题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1提示数据规模与约定二、分析1、递归建树2、树形DP 状态机DP(1)状态表示(2)状态转移三、…

C++11异步编程

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录前言1、std::future和std::shared_future1.1 std:future1.2 std::shared_future2、std::async3、std::promise4、std::packaged_task前言 C11提供了异步操作相关的类…

Vue3电商项目实战-结算支付 2【03-结算-对话框组件封装、04-结算-收货地址-切换】

文章目录03-结算-对话框组件封装04-结算-收货地址-切换03-结算-对话框组件封装 目的:实现一个对话框组件可设置标题,动态插入内容,动态插入底部操作按钮,打开关闭功能。 大致步骤: 参照xtx-confirm定义一个基础布局实…

MFC常用控件使用(文本框、编辑框、下拉框、列表控件、树控件)

简介 本文章主要介绍下MFC常用控件的使用,包括静态文本框(Static Text)、编辑框(Edit Control)、下拉框(Combo Box)、列表控件(List Control)、树控件(Tree Control)的使用。 创建项目 我们选择 文件->新建->新建项目,选择MFC程序 选择基于对话…

二叉树的三种遍历

二叉树的遍历可以有:先序遍历、中序遍历、后序遍历先序遍历:根、左子树,右子树中序遍历:左子树、根、右子树后序遍历:左子树、右子树、根下面是我画图理解三种遍历:二叉树里都是分为左子树和右子树。分治思…

Linux文件基础I/O

文件IO文件的常识基础IO为什么要学习操作系统的文件操作C语言对于函数接口的使用接口函数介绍如何理解文件文件描述符重定向更新给模拟实现的shell增加重定向功能为什么linux下一切皆文件?缓冲区为什么要有缓冲区缓冲区对应的刷新策略缓冲区的位置在哪里文件的常识 …

VSCode:添加SSH远程连接

有的时候我们的代码保存于远程服务器,通过VSCode可以通过SSH进行连接,完成远程的编辑。在VSCode的扩展中安装Remote - SSH点击左侧工具栏的远程资源管理器,然后点加号输入ssh的机器及用户名选择一个用于保存ssh配置文件的路径,默认…

Tabs Studio 5.3.0 多功能标签 Crack

在 Visual Studio 2022 和 SQL Server Management Studio 中轻松处理任意数量和类型的文档 你爱写代码,不会好好扫描文档找到你需要切换到的文件名,然后扫描文件菜单下拉列表,然后求助于解决方案资源管理器或搜索。只有在您需要切换到另一个…

javascript入门基础

目录 前言 引入:html中嵌入javascript有三种方式 0. 变量(var、let) 1. 函数 1.1 普通函数 和 箭头函数 1.1.2 普通函数中的this 1.1.3 箭头函数没有自己的this 1.1.4 普通函数有arguments方法,箭头函数没有 1.1.5 箭头函…

MS python学习(9)

开始学习第二辑 more python for beginners talking about formating https://learn.microsoft.com/en-us/shows/more-python-for-beginners/formatting-and-linting–more-python-for-beginners-2-of-20 Formating 代码格式化:使用pylint工具来帮助遵循PEP8(pyt…

conda创建一个地理开发环境

conda创建一个地理开发环境1. 环境内包说明2. 创建yml文件3. 创建地理开发环境使用conda安装包的时候,经常遇到包之间相互冲突。为了方便配置环境,测试了常用的地理开发所需要的各种包,生成了yml文件方便一键安装。 Linux下pip基本可以成功安…

手敲Mybatis(七)-细化xml语句解析和构建

前言为什么这一章节要细分之前的解析xml处理逻辑,原因是违反了单一原则设计,职责并不明确,将Sql语句、参数、返回值等等一切都进行解析,那么这种的需要拆开,为了后面可维护可扩展,例如Mapper级别的有mapper…