【编程好习惯】通过命名规则区分变量 推荐
2010-01-07 09:00
302 查看
通过一定的命名规则区分结构变量、函数参数和局部变量,有助于提高程序的可读性。比如,图1就是采用笔者所惯用的命名规则所写出来的程序。这一规则是:
1) 对于结构或C++类中的成员变量,在变量名的后面加一个“_”。
2) 在函数的参数名前加一个“_”。
3) 局部变量和全局变量则不在其前、后加“_”。
example.c
00123: typedef struct dll_node
00124: {
00125: struct dll_node *prev_;
00126: struct dll_node *next_;
00127: } dll_node_t;
00128:
00129: static bool mem_find_neighbor (dll_node_t *_p_node, void *_p_key)
00130: {
00131: maddr_t addr = *(maddr_t *)_p_key;
00132: mnode_t *p_mnode = (mnode_t *)_p_node;
00133: mnode_t *p_next = (mnode_t *)p_mnode->node_.next_;
00134:
00135: if (p_next == 0 || p_mnode->addr_ > addr) {
00136: return false;
00137: }
00138:
00139: // we try to find the node that its address is less than [addr]
00140: // but the address of following node is bigger than [addr]
00141: if ((p_mnode->addr_ < addr) && (p_next->addr_ > addr)) {
00142: return false;
00143: }
00144:
00145: return true;
00146: }
图1
在很多情形下,需要在函数内部定义局部变量,且有时所定义的局部变量名与函数的传入参数名可能存在同名。如果不采用命名规则区别函数参数和局部变量,那可能需要定义一个xxx_temp局部变量,如此一来其可读性不是很好。采用笔者的方法,则如果函数参数是_xxx,仍就可以定义一个局变量名xxx。当程序的读者看到这两个变量时,就能快速的知道两者的功能是一致的,只不过一个是函数的参数,而另一个则是函数内部的局部变量。
1) 对于结构或C++类中的成员变量,在变量名的后面加一个“_”。
2) 在函数的参数名前加一个“_”。
3) 局部变量和全局变量则不在其前、后加“_”。
example.c
00123: typedef struct dll_node
00124: {
00125: struct dll_node *prev_;
00126: struct dll_node *next_;
00127: } dll_node_t;
00128:
00129: static bool mem_find_neighbor (dll_node_t *_p_node, void *_p_key)
00130: {
00131: maddr_t addr = *(maddr_t *)_p_key;
00132: mnode_t *p_mnode = (mnode_t *)_p_node;
00133: mnode_t *p_next = (mnode_t *)p_mnode->node_.next_;
00134:
00135: if (p_next == 0 || p_mnode->addr_ > addr) {
00136: return false;
00137: }
00138:
00139: // we try to find the node that its address is less than [addr]
00140: // but the address of following node is bigger than [addr]
00141: if ((p_mnode->addr_ < addr) && (p_next->addr_ > addr)) {
00142: return false;
00143: }
00144:
00145: return true;
00146: }
图1
在很多情形下,需要在函数内部定义局部变量,且有时所定义的局部变量名与函数的传入参数名可能存在同名。如果不采用命名规则区别函数参数和局部变量,那可能需要定义一个xxx_temp局部变量,如此一来其可读性不是很好。采用笔者的方法,则如果函数参数是_xxx,仍就可以定义一个局变量名xxx。当程序的读者看到这两个变量时,就能快速的知道两者的功能是一致的,只不过一个是函数的参数,而另一个则是函数内部的局部变量。
相关文章推荐
- 编程中常见的变量、函数、类的命名规则
- python 学习记录(5)-变量、模块名的命名规则及random模块使用
- VBS基础篇 - 变量(2) - 命名规则
- 三种编程命名规则(匈牙利法、大驼峰法、小驼峰法)
- C#中的变量、类、函数等的命名规则
- ASP.NET里的变量命名规则
- C语言初学者编程规范—命名规则
- 三种编程命名规则(匈牙利法,小驼峰法,大驼峰法)
- MFC变量命名示例 & 单词缩写规则
- C语言基础之变量的命名规则、定义常量、C的数据类型
- C++变量有什么命名规则
- Java标示符及变量命名规则
- 变量名命名规则,构造方法的作用,类名命名规则
- Python 变量作用域 —— 命名空间与 LEGB 规则
- C#编程--命名规则
- C++程序变量命名推荐规范
- 三种编程命名规则(匈牙利法,小驼峰法,大驼峰法)
- Oracle编程变量命名规范
- 变量、数据类型以及命名规则
- 高质量编程之命名规则