我有以下代码,用于打印自上次修改文件以来经过的时间:

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

08-16 14:08