编写优质无错代码} b. char Uptolower(char ch){ assert(ch >= ‘A’ && ch <= ‘Z’); if(ch >= ‘A’ && ch <= ‘Z’) return ch+=‘a’-’A’; return ch; } c. char Uptolower(char ch){ assert(ch >= ‘A’ && ch <= ‘Z’); return ch+(‘a’-’A’); } 分析: a.该函数检查ch是否在A..Z之间,如果是,则返回相应的小写字符,如果不是,则返回-1。缺点在于:把错误标志值和计算结果混在一起使用,容易造成使用者的误会。 b.该函数使用了断言,如果ch在A..Z之间则返回相应的小写字符,如果不是,断言会起作用,程序发生错误并退出。而最后一个return ch;则是在release的时候,如果不是A..Z之间,则返回原来的字符。但是,从书写效率上来说,这个函数稍微罗嗦了一点。因为它重复使用了断言和if判断。 c.该函数也使用了断言,返回相应大写字母的小写字母。 使用断言的好处:
断言使用举例: void memcpy(void * pvTo,void *pvFrom,size_t size){void *pbTo= (byte *)pvTo; void *pbFrom= (byte * pvFrom); assert(pvTo !=NULL && pvFrom !=NULL); assert(pbTo >= pbFrom +size' 'pbFrom >= pbTo+size); … } 使用断言的规则:
断言小结:
写到这里,我们初步探讨了编写优质无错代码的必要性,原则,和相关经验。 留几个练习题目,大家也参与一下讨论吧。
下面的memset函数实现有什么问题? void *memset(void *pv, byte b, size_t size){ byte *pb = (byte *)pv; unsigned long l; size_t sizeSize; l = (b << 8) | b; /* 用4个字节拼成一个long */ l = (l << 16) | l; pb = (byte *)longfill((long *)pb, l, size/4); size = size % 4; while (size-- > 0) *pb++ = b; return (pv); } 下面的代码用memset将三个局部变量置为0,请问可能会有什么问题? void DoSomeThing(...){ int i; int j; int k; memset(&k, 0, 3*sizeof(int)); // 将i,j,k置为0 ... } 定义结构如下: typedef struct{ char c1; char c2; int n; } stru; 请问sizeof(stru)等于多少?并说明理由。 下面是C语言中两种if语句判断方式。请问哪种写法更好?为什么? int n;if (n == 10) // 第一种判断方式 if (10 == n) // 第二种判断方式 下面的代码有什么问题? void DoSomeThing(...){ char* p; ... p = malloc(1024); // 分配1K的空间 if (NULL == p) return; ... p = realloc(p, 2048); // 空间不够,重新分配到2K if (NULL == p) return; ... } 下面的代码有什么问题? char *DoSomeThing(...){ char str[16]; ... return str; } 下面的代码有什么问题? char *_strdup( const char *strSource ){ static char str[MAX_STR_LEN]; strcpy(str, strSource); return str; } 下面的代码有什么问题?并请给出正确的写法。 try{FILE* fp = fopen("c:1.dat"); if (NULL != fp) { ... } fclose(fp); } except(EXCEPTION_EXECUTE_HANDLER){ } 我敲字敲累了,告一段落吧。不过,讨论会并不止讨论了这些内容,还有很多内容我没有写完,比如,函数的界面, 编写代码的风险, 编程的态度等等问题。作为补充,我把讨论会的幻灯片修改成了文本版本,作为另外一篇文章放在这里,以便对这个话题感兴趣的网友们参考。有什么问题,欢迎来信 ariesram@linuxaid.com.cn 继续探讨。 上一篇:一个被入侵网站分析报告 下一篇:系统恢复指南 更多相关文章
|
推荐文章
精彩文章
·日志管理
|