往期文章:
C规范编辑笔记(一)
C规范编辑笔记(二)
C规范编辑笔记(三)
C规范编辑笔记(四)
C规范编辑笔记(五)
C规范编辑笔记(六)
C规范编辑笔记(七)
C规范编辑笔记(八)
C规范编辑笔记(九)
C规则编辑笔记(十)
C规范编辑笔记(十一)
C规范编辑笔记(十二)
C规范编辑笔记(十三)
正文:
今天我们来把最后一篇(第十四篇)C规范编辑笔记讲完,就正式结束了这C规范编辑笔记系列。从第一篇2022年9月5号更新到今天2023年1月22号,陆陆续续也差不多花了四个半月时间~,终于今天要收尾了。好了,话不多说,我们直接开始先讲。
1、规则——不要使用 setjmp() 和 longjump() 函数。另外建议错误返回相应的数字来代表不同情况下的错误,不建议使用exit();
*** setjmp.h 库中定义的主要用于 C 中异常处理的 setjmp() 和 longjump() 函数很容易导致未定义的行为,因此不应使用。
Bad example:
#include <stdlib.h>
#include <stdio.h>
int read_file(void)
{
FILE *f = fopen("C:\\myfile.txt", "w");
if (NULL == f)
{
/* 打开文件时出现问题 */
_Exit(12);
}
fprintf(f, "%s", "blablabla");
...
abort();
...
return 0;
}
int main(void)
{
int val = read_file();
...
return 1;
}
Good example:
#include <stdlib.h>
#include <stdio.h>
int read_file(void)
{
FILE *f = fopen("C:\\myfile.txt", "w");
if (NULL == f)
{
/* 打开文件时出现问题 */
return 12; /* 针对此问题记录的错误代码 */
}
fprintf(f, "%s", "blablabla");
...
return 10; /* 其他记录的错误代码 */
...
return 0; /* 没有问题 */
}
int main(void)
{
int val = read_file();
if (val == 0)
{ /* 功能没问题 */
...
return 0;
}
else
{ /* 根据错误码进行错误处理*/
...
return 1;
}
}
2、规则 — 不要使用 setjmp.h 和 stdarg.h 标准库。
*** 当标准库中存在不同版本的函数时,必须使用“更安全”的版本。
3、所有注释中禁止使用字符序列“/*”和“//”,并且在//引入的注释中禁止使用行拼接字符“\”,因为它会导致未定义的行为。
4、非空文件的最后一行必须以换行符结尾。绝大多数发布者,尤其是在 Linux 环境中,会在关闭文件时自动且不可见地添加此换行符。
***非空文件不得在注释或预处理器指令的中间结束。
5、使用关键字 typedef 定义的类型名称必须小写,后缀为 _t。组成类型名称的单词必须用下划线字符分隔。
好了,我们最后一篇C规范编辑笔记就到这里了,终于将这个经历了四个半月的系列结束了,过程中也是三天打鱼两天晒网,后面有机会的话,会多更新一点关于实操过程中遇到的一些错误解决分享和一些经验分享,同时也会更新自己的一些笔记系列~
同时今天也是新年第一天,祝大家新年快乐~
本人水平有限,上述信息仅供学习参考,如有错误和不妥之处,请多多指教。
另外创作不易,请勿抄袭,如果有帮助到大家的话希望大家可以点个赞,谢谢~