小锋学长生活大爆炸
C编程规范整理
关注作者
前往小程序,Get
更优
阅读体验!
立即前往
腾讯云
开发者社区
文档
建议反馈
控制台
登录/注册
首页
学习
活动
专区
工具
TVP
腾讯云架构师技术同盟
文章/答案/技术大牛
搜索
搜索
关闭
发布
首页
学习
活动
专区
工具
TVP
腾讯云架构师技术同盟
返回腾讯云官网
小锋学长生活大爆炸
首页
学习
活动
专区
工具
TVP
腾讯云架构师技术同盟
返回腾讯云官网
社区首页
>
专栏
>
C编程规范整理
C编程规范整理
小锋学长生活大爆炸
关注
发布于 2020-10-29 11:11:11
发布于 2020-10-29 11:11:11
830
0
举报
文章被收录于专栏:
小锋学长生活大爆炸
小锋学长生活大爆炸
只有当函数只有10行甚至更少时才会将其定义为
内联函数
(inline function)。当函数体比较小的时候,内联该函数可以令目标代码更加高效。内联那些包含
循环
或
switch
语句的函数是
得不偿失
的。如果一个inline函数会在多个源文件中被用到,那么
必须
把它定义在**.h头文件**中。
定义函数时,参数顺序为:
输入参数在前,输出参数在后
。这一点并不是必须遵循的规则,
输入/输出
两用参数(通常是类/结构体变量)混在其中,会使得规则难以遵循。
包含文件的名称及次序:C库、C++库、其他库的.h、项目内的.h。
编写短小函数。长函数有时是恰当的,因此对于函数长度并没有严格限制。如果函数超过
40行
,可以考虑在不影响程序结构的情况下将其分割一下。
const使用。强烈建议你在任何可以使用的情况下都要使用const。
类型命名。类型命名每个单词以
大写字母
开头,不包含下划线:MyExcitingClass、MyExcitingEnumo。所有类型命名——类、结构体、类型定义(typedef)、枚举——使用相同约定。
变量命名。变量名一律
小写
,单词间以
下划线
相连,类的成员变量以下划线结尾,如my_exciting_local_variab1e、my_exciting_meber_variab1e_。
全局变量。可以以
g_
或其他易与局部变量区分的标志为前缀。
普通函数。大小写混合,函数名以
大写字母
开头,每个单词
首字母大写
,没有下划线:AddTab1eEntry()、DeleteUr1()。
存取函数。存取函数要与存取的变量名匹配:set_my_exciting_member_variab1e() 。
其他短小的内联函数名也可以使用小写字母,例如,在循环中调用这样的函数甚至都不需要缓存其值,小写命名就可以接受。
枚举命名。
枚举值
应
全部大写
,单词间以
下划线
相连:MY_EXCITING_ENUM_VALUE。
枚举名称
属于类型,因此
大小写混合
:Ur1Tab1eErrors。
宏命名。其命名像枚举命名—样全部大写、使用下划线。
注意永远不要用自然语言翻译代码作为注释,要假设读你代码的人C/C++比你强。
TODO注释。对那些
临时的、短期的
解决方案,或已经够好但
并不完美
的代码使用TODO注释。后面括号里加上你的
大名、邮件地址
等,还可以加上冒号:,目的是可以根据统一的TODO格式进行查找:
全局变量要有较详细的注释,包括对其功能、取值范围以及存取时注意事项等的说明。
注释应放在其代码
上方相邻位置
或
右方
,不可放在下面。如放于上方则需与其上面的代码用
空行
隔开,且与下方代码缩进相同。
对于switch语句下的case语句,如果因为特殊情况需要处理完一个case后进入下一个case处理,必须在该case语句处理完、下一个case语句前加上明确的注释。
避免在注释中使用缩写,除非是业界通用或子系统内标准化的缩写。
注释应考虑程序易读及外观排版的因紊,使用的语言若是中、英兼有的,建议
多使用中文
,除非能用非常流利准确的英文表达。对于有外籍员工的,由产品确定注释语言。
文件头、函数头、全局常量变量、类型定义的注释格式采用工具可识别的格式(如doxygen)。
相对独立的程序块之间、变量说明之后必须加空行。
多个短语句(包括赋值语句)不允许写在同一行内,即一行只写一条语句。
使用断言记录内部假设。不能用断言来检查运行时错误。
确保所有字符串是以NULL结束。
本文参与
腾讯云自媒体同步曝光计划
,分享自作者个人站点/博客。
原始发表:2020/10/22 ,如有侵权请联系
cloudcommunity@tencent.com
删除
前往查看
编程算法
c++
本文分享自
作者个人站点/博客
前往查看
如有侵权,请联系
cloudcommunity@tencent.com
删除。
本文参与
腾讯云自媒体同步曝光计划
,欢迎热爱写作的你一起参与!
编程算法
c++
评论
登录
后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档
专栏文章
快讯文章归档
关键词归档
开发者手册归档
开发者手册 Section 归档
0
0
0
推荐