了解对 ctime() 的连续调用

发布于 2024-12-26 12:38:11 字数 909 浏览 0 评论 0原文

我有一个关于 glibc ctime() 如何工作的问题。

下面是我的代码片段:

#include    <stdio.h>
#include    <time.h>
#include    <stdlib.h>


int main (int argc,char** argv)
{
    int ret=EXIT_SUCCESS;

    time_t tm1;
    time_t tm2;


    tm1 = time(NULL);
    tm2 = tm1 + 60; // 60 seconds later


    puts("1st method-------");
    printf("tm1 = %stm2 = %s",ctime(&tm1),ctime(&tm2));


    puts("2nd method-------");
        printf("tm1 = %s",ctime(&tm1));
    printf("tm2 = %s",ctime(&tm2));

    return(ret);
}

我得到:

1st method-------
tm1 = Sat Jan 14 01:13:28 2012
tm2 = Sat Jan 14 01:13:28 2012
2nd method-------
tm1 = Sat Jan 14 01:13:28 2012
tm2 = Sat Jan 14 01:14:28 2012

如您所见,在第一种方法中,两个 tm 具有相同的值,这是不正确的。在第二种方法中我得到了正确的值。 我知道 ctime() 将这些字符串放入静态缓冲区中,要覆盖它,我们需要连续调用 ctime()。

问:我在第一种方法中不进行连续调用吗?

谢谢您的回复。

I have a question about how the glibc ctime() works.

Follows my snippet:

#include    <stdio.h>
#include    <time.h>
#include    <stdlib.h>


int main (int argc,char** argv)
{
    int ret=EXIT_SUCCESS;

    time_t tm1;
    time_t tm2;


    tm1 = time(NULL);
    tm2 = tm1 + 60; // 60 seconds later


    puts("1st method-------");
    printf("tm1 = %stm2 = %s",ctime(&tm1),ctime(&tm2));


    puts("2nd method-------");
        printf("tm1 = %s",ctime(&tm1));
    printf("tm2 = %s",ctime(&tm2));

    return(ret);
}

I got:

1st method-------
tm1 = Sat Jan 14 01:13:28 2012
tm2 = Sat Jan 14 01:13:28 2012
2nd method-------
tm1 = Sat Jan 14 01:13:28 2012
tm2 = Sat Jan 14 01:14:28 2012

As you see, in the first method both tm have the same value which is not correct. In the 2nd method I got correct values.
I know that ctime() puts those string in static buffer, and to overwrite it we need a successive call to ctime().

Q: Do I not doing successive call in 1st method?

Thank you for reply.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

守不住的情 2025-01-02 12:38:11

您已提供解决问题所需的所有信息。

第二种方法如您所期望的那样工作:调用 ctime,填充缓冲区,然后打印结果;然后重复这个过程。这样你就可以打印出两个不同的时间。

对于第一种方法,顺序不同:调用 ctime,然后再次调用它,然后才打印结果。每次调用 ctime 的结果都是相同的,至少就 printf 而言:静态缓冲区的地址。但是每次调用都会更改该缓冲区的内容,并且由于 printf 在两个 ctime 调用完成之前不会查看缓冲区,因此它最终会打印较新的内容两次。

因此,您正在第一个方法中进行两个调用,只是第一个调用的结果在打印之前被覆盖。

You've provided all the info necessary to solve the problem.

The second method works as you'd expect: ctime gets called, fills the buffer, and the results get printed; this process is then repeated. So you get the two distinct times printed.

For the first method, the order is different: ctime is called, then it is called again, and only then do the results get printed. The results from each call to ctime is the same, at least as far as printf is concerned: the address of the static buffer. But the contents of that buffer was changed by each call, and since printf doesn't look in the buffer until both ctime calls are done, it ends up printing the newer contents twice.

So you ARE making both calls in the first method, its just that the results of the first call get overwritten before they get printed.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文