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


相关推荐
yujunl1 天前
U9系统admin用户账号密码生成Do方法
开发语言
MaikieMaiky1 天前
C++ STL 系列(一):string 容器详解与示例
开发语言·c++
之歆1 天前
DAY_25 JavaScript 原型、原型链与值类型/引用类型 ── 深度全解(下)
开发语言·javascript·ecmascript
段ヤシ.1 天前
回顾Java知识点,面试题汇总Day7(持续更新)
java·开发语言
努力努力再努力wz1 天前
【Qt入门系列】深入理解信号与槽:从事件响应到自定义信号机制
c语言·开发语言·数据结构·数据库·c++·qt·mysql
在角落发呆1 天前
DTU 数据转发服务器:工业物联网的隐形桥梁
开发语言·php
Sakuyu434681 天前
C语言基础--基本数据类型
c语言·开发语言
在坚持一下我可没意见1 天前
Python 修仙修炼录 05:循环神通,省去无用苦修
开发语言·python·面试·入门·循环·复习
Hua-Jay1 天前
OpenCV联合C++/Qt 学习笔记(二十)----Harri角点检测、Shi-Tomas角点检测及亚像素级别角点位置优化
c++·笔记·qt·opencv·学习·计算机视觉
techdashen1 天前
Rust 社区在 4 月做了什么:项目管理月报解读
开发语言·rust·mfc