谷歌C语言编码规范详解

文件命名
  • 源文件和头文件 :文件名使用小写字母和下划线分隔。例如:my_source_file.cmy_header_file.h
包含保护
  • 头文件应使用包含保护,以防止重复包含。例如:

    #ifndef MY_HEADER_FILE_H_
    #define MY_HEADER_FILE_H_

    // 内容

    #endif // MY_HEADER_FILE_H_

注释
  • 使用/* ... */块注释和//行注释。注释应清晰、简洁,放在代码相关部分的上方或右侧。
缩进和对齐
  • 使用2个空格进行缩进。
  • 代码块应使用一致的对齐风格。
变量和结构体成员
  • 使用驼峰命名法(camelCase),如myVariablemyStructMember
函数名
  • 使用下划线命名法(snake_case),如my_function_name
结构体名称
  • 使用首字母大写的驼峰命名法(PascalCase),如MyStruct
枚举
  • 枚举类型使用首字母大写的驼峰命名法(PascalCase),如Color

  • 枚举成员使用全大写字母和下划线分隔的命名法(UPPER_SNAKE_CASE),如COLOR_RED

    typedef enum Color {
    COLOR_RED,
    COLOR_GREEN,
    COLOR_BLUE
    } Color;

宏定义
  • 使用全大写字母和下划线分隔的命名法(UPPER_SNAKE_CASE),如#define MAX_BUFFER_SIZE 1024
常量
  • 使用const关键字定义常量,而不是使用宏。
函数和参数
  • 函数应尽可能短小,并只做一件事。
  • 参数名称应清晰明了,使用驼峰命名法(camelCase)。
指针
  • 指针声明时将星号靠近变量名,如int *ptr
空间和括号
  • 运算符和关键词前后使用空格,括号内不使用空格。

    if (a == b) {
    func(a, b);
    }

错误处理
  • 使用明确的错误处理和返回值检查。
文件组织
  • 头文件包含依赖声明,源文件包含具体实现。
  • 头文件应包含函数声明、宏定义、类型定义等。
头文件依赖
  • 头文件应包含必要的依赖头文件。
静态函数
  • 非导出的函数应使用static关键字。

    static void helper_function() {
    // 实现
    }

分割大型项目
  • 大型项目应合理分割成多个文件和模块。

在项目开发过程中,按一定的规范编写代码,可以提高代码的可读性、一致性和可维护性。有助于确保代码库的高质量和协作效率。

相关推荐
2601_949146535 小时前
C语言语音通知接口接入教程:如何使用C语言直接调用语音预警API
c语言·开发语言
知南x7 小时前
【Ascend C系列课程(高级)】(1) 算子调试+调优
c语言·开发语言
2的n次方_8 小时前
Runtime 执行提交机制:NPU 硬件队列的管理与任务原子化下发
c语言·开发语言
凡人叶枫9 小时前
C++中智能指针详解(Linux实战版)| 彻底解决内存泄漏,新手也能吃透
java·linux·c语言·开发语言·c++·嵌入式开发
xuxg20059 小时前
4G 模组 AT 命令解析框架课程正式发布
stm32·嵌入式·at命令解析框架
凡人叶枫11 小时前
C++中输入、输出和文件操作详解(Linux实战版)| 从基础到项目落地,避坑指南
linux·服务器·c语言·开发语言·c++
傻乐u兔12 小时前
C语言进阶————指针3
c语言·开发语言
CodeSheep程序羊13 小时前
拼多多春节加班工资曝光,没几个敢给这个数的。
java·c语言·开发语言·c++·python·程序人生·职场和发展
I'mChloe13 小时前
PTO-ISA 深度解析:PyPTO 范式生成的底层指令集与 NPU 算子执行的硬件映射
c语言·开发语言
程序员良许13 小时前
三极管推挽输出电路分析
后端·嵌入式