薄荷萤火虫 2022-04-13 00:52 采纳率: 91.8%
浏览 16
已结题

关于代码产生系统时间的输出问题


#include <iostream>
#include <cstdio>
#include <sysKpes.h>
#include <unistd.h>
#include <time.h>
using namespace std;
int main()
{   
    time_t now;
    tm * timenow;
    while(true){
        time(&now);
        timenow = localtime(&now);
        cout<<"Those output come from child,"<<asctime(timenow)<<endl;
    }
}
#include <stdio.h> 
#include <time.h>
int main()
{   
    time_t now;
    while(1)
    {
        time(&now);
        
        time_t timeValue = 0;
        char *str = NULL;
    
        timeValue = time(NULL);
        str = ctime(&timeValue);
        printf("Those output come from child,%s\n",str);  
    }
    return 0;
}

为什么这个的C语言代码输出系统时间有点慢啊?c++的输出系统时间就很快,C语言的这个代码怎么样才能让它输出快点啊?

  • 写回答

1条回答 默认 最新

  • bostonAlen 2022-04-13 02:05
    关注

    不是时间问题,是cout和printf的区别
    而且不是你表面看的printf慢,其实不然,printf还快些。
    我们可以做一个测试。就循环1000次,打印时间。
    经过测试,发现while循环1000次,printf只打印一个时间比如时间是2:23:2,而cout打印了两个时间2:23:2和2:23:3。
    这说明cout花了至少1s多才打印了1000条,而printf只用了可能1s不到就打印了1000条。
    这就是为什么你看到cout的时间好像一直不动,很久才到下一秒一样。

    #include <iostream>
    #include <cstdio>
    #include <time.h>
    using namespace std;
    int main()
    {
        time_t now;
        tm * timenow;
        int t = 0;
        while (t<1000) {
            time(&now);
            timenow = localtime(&now);
            cout << t<<"Those output come from child," << asctime(timenow) << endl;
            t++;
        }
    
        return 0;
    }
    
    #include <stdio.h> 
    #include <time.h>
    int main()
    {
        time_t now;
        int t = 0;
        while (t<1000)
        {
            time(&now);
    
            time_t timeValue = 0;
            char *str = NULL;
    
            timeValue = time(NULL);
            str = ctime(&timeValue);
            printf("%dThose output come from child,%s\n", t,str);
            t++;
        }
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 4月21日
  • 已采纳回答 4月13日
  • 创建了问题 4月13日

悬赏问题

  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分