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 字符,保证在任何编辑器、平台、打印机中对齐完全一致,不会出现缩进错乱。


相关推荐
大尚来也3 小时前
Java反射机制:从底层原理到Spring框架的深度实践
开发语言
꧁꫞꯭零꯭点꯭꫞꧂3 小时前
前端面试题3
开发语言·前端·javascript
共享家95273 小时前
C++核心之多线程
开发语言·c++
南境十里·墨染春水3 小时前
C++ 笔记 function 函数包装器模板
开发语言·c++·笔记
研來如此3 小时前
tinyxml2 常用读取接口对照表
xml·c++·tinyxml2
MC皮蛋侠客3 小时前
C++中使用Redis指南:基于redis-plus-plus库
开发语言·c++·redis
星晨雪海3 小时前
Redis-逻辑查询详情讲解
java·开发语言