这是我相对简单的场景,我想知道是否可以为自己节省一个条件并整理一下代码。它的生产代码是别人写的,我正在整理。它根本没有 fclose,所以我添加的只是条件 fclose() 行:
FILE *fp;
struct stat sb;
/* snipped code */
if (((fp = fopen (config_file, "r+")) == NULL) || (fstat (fileno (fp), &sb))) {
syslog (LOG_ERR, "Fault. Unable to read config file");
if (fp != NULL) {
fclose (fp);
}
return -1;
}
/* code carries on after this */
问题是,我真的需要if(fp != null)
在我的代码中加入吗?只做fclose(fp)
不检查有什么影响?我阅读了 C89 标准,但我不清楚结果会是什么。
提前喝彩
史蒂夫