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


相关推荐
Anastasiozzzz1 分钟前
构建健壮软件系统的基石:深入解析面向对象设计七大原则
开发语言·javascript·设计模式·ecmascript
Dxy12393102165 分钟前
Python 请求:为什么 Session 比直接请求快 10 倍?
开发语言·python
dongf20198 分钟前
R 语言 逻辑斯蒂回归
开发语言·数据分析·回归·r语言
Irissgwe10 分钟前
C++ STL unordered系列关联式容器详解
开发语言·c++·stl·关联式容器
m0_5474866612 分钟前
华南农业大学《C语言程序设计》期末试卷及答案2018-2025年PDF
c语言·开发语言·pdf·c语言程序设计
fqbqrr8 小时前
2606C++,C++构的多态
开发语言·c++
biter down9 小时前
从 0 到 1 搭建 Python 接口自动化测试框架(博客系统实战)
开发语言·python
小欣加油9 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
Yolo_TvT10 小时前
C++:析构函数
c++