免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2094 | 回复: 4
打印 上一主题 下一主题

CGL编码规范V1.0 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-04-29 01:35 |只看该作者 |倒序浏览
http://www.cppblog.com/converse/archive/2007/04/28/23148.html

之前虽然在写代码的时候自己心中有一个编码的规范,但是毕竟没有述之文字,现在回头看了看发现还是有很多地方不够规范的,花了一个晚上扫了一下原有的代码,制定出这个规范,毕竟是写出来白纸黑字的,以后有依可循,这并不是最后的规范版本,我把它命名为V1.0,会根据需要不断的补充完善,并且会 check in到SF的SVN中去,有可能的话再写一份E文版的规范,而每次对规范的补充完善相应的都会进行对代码的重构。

这是一个好的习惯,希望我以后不管是作商业上的开发还是自己下面作着玩儿写的代码都按照这些流程走下来,我相信,好的习惯和风格会带来很多积极的影响。

CGL编码命名规范V1.0(2007-04-29)

1.变量命名采用匈牙利命名法,如下:
1)整型变量加前缀n
2)指针变量加前缀p
3)自定义也就是typedef声明的新类型变量加前缀t,而这些类型的定义后面加_t后缀,如iter_t
4)char类型加前缀c,char数组加类型sz
5)变量的命名一般为以上的前缀加上相应的描述名词,同时名词第一个字母大写,如piterator_t pIter

2.宏一律大写,并且加上前缀CGL_

3.函数名称加前缀cgl_,如果是某类型的接口函数加上类型名称,其后命名基本参照对应的STL中函数的命名,
    如cgl_list_clear与STL中list容器的clear函数对应
    但是还需要注意的是,如果是在某个文件中的static函数,也就是外部不能使用的函数,前缀改为cgls_
    而对于某个结构体内定义的函数指针类型不需要加上cgl前缀,只需要对函数功能进行说明就可以了,一般为
    动词+名词的形式命名。
    如iterator中的函数指针    data_t                    (*get_value)(piterator_t pIter);就是得到这个iterator
    值的函数。
   
    有了这个规则,那些在CGL中出现的没有这些前缀的函数都是C库中提供的库函数。
   
4.进行比较操作时把常量放在比较操作符左边,如if(NULL != pIter)

5.自定义的数据类型以及结构体的命名习惯为描述该类型的名词 + "_t",如iterator_t,如果是指向该类型
  变量的指针类型则在前面加上p前缀,如piterator_t
  
6.头文件中为防止重复包含所声明的宏命名规范为该头文件的去掉".h"后缀之后的文件名再加上"_H"后缀,
    同时这个组合的前后都要加上"__",如cgl_commondef.h头文件中的宏为__CGL_COMMONDEF_H__
   
7.每个文件都要以“CGL_BEGIN”开始,以“CGL_END”结尾

8.不可忽略编译时的警告信息,如果在操作中需要强制转换的要明确写出来,不应依赖于编译器隐式的转换。

9.文件的命名为cgl_前缀加上该文件的描述,一般的,这个后缀与STL中对应的文件名相同,如STL中的list文件
  其在CGL中的对应头文件就是cgl_list.h,c文件就是cgl_list.c
  
10.所有函数的定义前面一律加上对函数功能,输入,输出参数的注释说明  

论坛徽章:
0
2 [报告]
发表于 2007-04-29 01:36 |只看该作者
无耻的转了小C的文章~~

论坛徽章:
0
3 [报告]
发表于 2007-04-29 09:26 |只看该作者

论坛徽章:
0
4 [报告]
发表于 2007-04-29 23:48 |只看该作者
原帖由 converse 于 2007-4-29 09:26 发表


论坛徽章:
0
5 [报告]
发表于 2007-04-30 00:21 |只看该作者
二位老大,要改变编码风格一定要慎重啊。。。兄弟去年上半年因为改变风格,辛苦了大半年啊
就像玩暗黑一样,一定要事先用A计算器,B计算器,计算出一个完美的亚马逊后,才开始升级,加点,否则。。。

不过原来俺的老大要求的是整形变量前加 i,char* 加 lpsz,呵呵
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP