C++ 源码文本格式规范

先说规范:

  • 字符编码UTF-8(无 BOM) → 统一文字存储,跨平台不乱码、不报错。
  • 换行符格式LF → 统一换行格式,避免 Git 与跨平台异常。
  • 缩进格式空格缩进 → Tab 键转为空格,无真实 Tab,保证对齐一致。

字符编码:UTF-8(无 BOM)

Unicode UTF-8 编码 是跨平台通用标准编码,支持中英文、符号、特殊字符,兼容性最强。同时无BOM头(EF BB BF) 可避免在 Linux、macOS、编译器、Git 等工具中出现开头乱码、编译报错、头文件提前输出等问题。


换行符格式:LF

Windows 默认换行符:CRLF(\r\n),Linux/macOS/Git/编译器中则是:LF(\n)。统一 LF 可避免:Git 提示换行符变更警告,跨平台编译、脚本执行异常,代码行尾出现多余不可见字符等问题。

为避免Git 提示换行符变更警告,可在源文件根目录添加.gitattributes文件:

cmd 复制代码
# 统一源码换行符为 LF
*.{h,cpp,cmake} text eol=lf

# Windows 相关可保留 CRLF
*.{cmd,bat,ps1} text eol=crlf

# 二进制文件不处理(图片/压缩包/字体等)
*.{png,jpg,jpeg,gif,ico,svg,zip,7z,tar.gz,rar,pdf,exe,dll,bin} binary

或:

cmd 复制代码
# 强制所有文件使用 LF 换行符
* text=auto eol=lf

# Windows 相关可保留 CRLF
*.{cmd,bat,ps1} text eol=crlf

# 二进制文件不处理(图片/压缩包/字体等)
*.{png,jpg,jpeg,gif,ico,svg,zip,7z,tar.gz,rar,pdf,exe,dll,bin} binary

缩进格式:空格缩进(Space Indent)

Tab 不是固定 4 个空格,也不是固定 8 个空格。它是一个控制字符,含义是:跳到下一个制表位(tab stop)。不同编辑器显示宽度不同。

当缩进使用空格(Space) ,不使用真实 Tab 字符(\t)。虽然按下 Tab 键的 ,但实际插入若干个空格(通常 4 个或 2 个) ,所看见宽度在任何编辑器中都相同 。由于文件中不存在真实 Tab 字符,保证在任何编辑器、平台、打印机中对齐完全一致,不会出现缩进错乱。


相关推荐
小糖学代码1 天前
LLM系列:1.python入门:15.JSON 数据处理与操作
开发语言·python·json·aigc
handler011 天前
从源码到二进制:深度拆解 Linux 下 C 程序的编译与链接全流程
linux·c语言·开发语言·c++·笔记·学习
小白学大数据1 天前
现代Python爬虫开发范式:基于Asyncio的高可用架构实战
开发语言·爬虫·python·架构
渔舟小调1 天前
P19 | 前端加密通信层 pikachuNetwork.js 完整实现
开发语言·前端·javascript
不爱吃炸鸡柳1 天前
数据结构精讲:树 → 二叉树 → 堆 从入门到实战
开发语言·数据结构
网络安全许木1 天前
自学渗透测试第21天(基础命令复盘与DVWA熟悉)
开发语言·网络安全·渗透测试·php
t***5441 天前
如何在Dev-C++中使用Clang编译器
开发语言·c++
码界筑梦坊1 天前
93-基于Python的中药药材数据可视化分析系统
开发语言·python·信息可视化
Qbw20041 天前
【Linux】进程地址空间
linux·c++
Cosmoshhhyyy1 天前
《Effective Java》解读第49条:检查参数的有效性
java·开发语言