一个规范的编程习惯,完全可以给程序的编写和自身的调试带来极大的便利。同时也会增强自己代码的可读性,让别人更快的理解我们的思路。
1.文件命名规则
所有的Cv和CvAux库文件的命名必须符合以下规则。
1)前缀位cv;
2)C/C++头文件扩展名为”.h”,C++头文件扩展名为”.hpp”;
3)源文件扩展名”.cpp”;
4)文件名小写,兼容POSIX;
2.数据类型和函数的命名规则
函数和数据结构使用大小写混合样式:
1)外部函数使用前缀cv。
2)内部函数使用前缀icv。
3)数据结构(C结构体,枚举,联合体,类)使用前缀Cv。
宏名称全部使用大写字符,词间下划线分割,外部宏使用前缀CV_,内部宏使用前缀ICV_。
3.文件结构
1>源文件以BSD兼容的许可声明开头
2>每行最多90字符(粗略),不包括行结束符。
3>不是制表符,使用4空格缩进。
4>头文件必须使用保护宏。
5>混合C/C++ 接口文件使用 extern ”C”{}
6>VC++下编译,源文件必须包含预编译头precomp.h。
4.函数接口设计
为了保持库的一致性,应根据以下方式设计接口:
1>函数功能:定义良好,精简
2>函数名称:简单,体现函数功能。一般形式为cv+ActionName+Object+modeifiers
对容器元操作时,函数名为 ContainerName+ActionName
3>函数返回值:以简化功能为目的。不能使用会导致严重错误的类型(空指针、0除数、错误参数类型、不支持的图像格式等)作为返回值
4>参数类型:尽量使用Opencv中的常用数据结构类型:光栅图像IplImage(CV 1.X),矩阵CvMat(常用于图像矩阵 CV2.X~)、轮廓线CvSeq等。不建议使用简单指针等。
5>参数顺序:输入参数、输出参数、标记或可选参数。输入参数一般用const修饰。对于矩阵操作或类局域函数(一般为内部函数)顺序为:容器(指针),元素信息(位置)、标记或可选参数。可选参数或标记根据重要性依次排列,一般可赋初值。
6>参数默认值:简化函数用法。C++编程环境中函数的参数可赋予默认值。在函数声明中,使用宏CV_DEFAULT指定参数的默认值,与C语言编程环境相兼容。
可参考CV_DEFAULT宏定义
#ifndef CV_DEFAULT
# ifdef __cplusplus
# define CV_DEFAULT(val) = val
# else
# define CV_DEFAULT(val)
# endif #endif
5.函数实现
主要对参数类型检测、错误产生和处理、内存管理和资源回收、调用低级函数做出了规定:
1>参数类型检测:OpenCV广泛使用高级数据类型传送和返回参数。简化了函数使用,却增加了错误参数调用函数的可能性。因此在使用输入参数和返回参数时应该检查参数类型是否正确。例如IplImage通过宏CV_CHECK_IMAGE被检查。CV_CHECK_MASK_IAMGE可检查掩码图像。
2>错误产生和处理:任何时候,当传入一个错误的参数或在函数执行时发生其他严重错误时,应该通过cvError函数抛出一个错误信号。Opencv的错误机制是用一个全局错误状态代替返回错误码,实现方法是使用cvError函数设置、用cvClearErrStatus清除、用cvGetErrorStatus读取。除了设置错误状态和指定值外,cvError还能进行其他操作,依据错误处理的模式的不同而不同,错误处理模式可以通过cvSetErrorMode调整。在Silent模式或parent模式下,cvError以及返回;在子模式下,它打印错误消息并终止应用程序。为了更方便的使用,可以通过使用宏来代替以上函数,如CV_ERROR和OPENCV_ERROR。用CV_CALL和OPENCV_CALL来代替函数和检查状态。
3>内存管理和资源回收:在opencv中临时缓存用cvAlloc和cvFree函数分配和回收。函数应该注意适当对齐,对未释放的内存保存跟踪并检查溢出。临时图像、内存存储和其他结构使用cvCreate
4>调用低级函数:OpenCV中的低级函数主要是用C语言实现的原始操作。它们主要使用简单指针和基本数值类型,几乎不使用结构体,也不同于前面谈论的错误处理方法,错误返回代码而不是全局错误状态。调用这些函数的安全方法是使用宏IPPI_CALL。
6.代码布局
每个文件必须使用一致的格式。
修改别人的代码,应与原代码格式一致。
7.可移植性
为了满足可移植性:
1>ANSI C 第一个语言标准ISO/IEC 9899-1990.
2>C9X(1999年修订的新标准):ISO/IEC 9899
3>C++标准:ISO/IEC 14882-1998.
去掉依赖编译器或者平台和系统调用的一些写法:
1>编译器:pragma’s
2>特定关键字:_stdcall、_inline 和_int64,应分别使用CV_INLINE、CV_STDCALL和int64代替。
3>编译器扩展
4>内联汇编
5>Unix或Win32调用
6>用sizeof代替具体的数据大小,用简单的字符处理数据,使用短形式或使用预处理指令包含非可移植性代码片段。
8.文档编写
文档以HTML格式提供。每个函数的文档或相关函数组的文档放入不同文件中,该文件可以通过主页连接访问。函数文档的HTML文档顺序包含以下基本元素。
1>页面标题:显示在浏览器标题栏中,表示一个扩展的函数名或一组函数名
2>关键字列表:用于搜索引擎和各种工具检索文档
3>可见的页面标题:重复页面标题
4>函数名:真实函数名,作为标签
5>简介:单行函数描述、
6>函数声明:按其在头文件中的形式,用
包含,7>函数参数描述:用格式<参数名,描述>表示的列表。
8>讨论:描述函数功能、允许或支持的参数组合的限制、算法参考
9>使用实例:可选的代码片段或伪代码,几个相关的函数可以一并参考一个实例。
10>请参考:包括零个或多个
下表是毛星云—《Opencv编程入门》里面提到的命名规则,可以借鉴:书中还提到一种匈牙利命名法:变量名=属性+类型+对象描述;
编程规范来自刘海波-《visual C++数字图像处理技术详解》