我有以下代码,用于打印自上次修改文件以来经过的时间:
int main(int argc, const char * argv[]) {
struct stat fileInfo;
char * dir = "/Users/jenna/Desktop/Random.rtf";
stat(dir, &fileInfo);
printf("Last modified time: %s\n", ctime(&fileInfo.st_mtime));
time_t mytime;
mytime = time(NULL);
printf("Current time: %s\n", ctime(&mytime));
double diff = difftime(ctime(&mytime), ctime(&fileInfo.st_mtime));
printf("diff : %f\n", diff);
}
不幸的是,此代码提供以下输出:
Last modified time: Wed Apr 6 00:15:30 2016
Current time: Wed Apr 6 00:17:29 2016
diff : 0.000000
当我将printf中的format标志更改为
%d
时,会得到以下输出:Last modified time: Wed Apr 6 00:15:30 2016
Current time: Wed Apr 6 00:18:34 2016
diff : 1983419808
两个输出都不正确,因为我期望的差异只有几分钟(以秒表示)。我在这里做错什么了?谢谢你的帮助。
最佳答案
你应该练习启用编译器警告。这段代码应该会提供一些非常有用的代码。具体来说,您将char*
值传递到difftime
。
由于ctime
总是返回指向同一静态内存的指针,因此对ctime
的两个调用返回同一指针。现在您隐式地将它们转换为time_t
(编译器警告!!!),得到的差为零。
在第二种情况下,您将adouble
传递到printf
并告诉它您传递了一个int
,这是未定义的行为。
实际上,您需要将time_t
值传递到difftime
中,如下所示:
double diff = difftime( mytime, fileInfo.st_mtime );
printf( "diff : %f\n", diff );
并养成阅读不熟悉的功能文档的习惯:
Reference for
difftime
Reference for
ctime