我是靠谱客的博主 踏实马里奥,最近开发中收集的这篇文章主要介绍linux mktime很耗时,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

linux写了程序,发现某个线程执行速度很慢,最终用google-perftools分析定位出来是linux 函数mktime执行较慢,由于线程要执行多次mktime,导致整个线程执行很慢

 tm tmp_time ;
 tmp_time.tm_hour = m_FrameInfo->nHour /*- 1*/ ;
 tmp_time.tm_min  = m_FrameInfo->nMinute /*- 1*/ ;
 tmp_time.tm_sec  = m_FrameInfo->nSecond /*- 1*/ ;
 tmp_time.tm_mday = m_FrameInfo->nDay  /*+ 1*/;
 tmp_time.tm_mon  = m_FrameInfo->nMonth - 1 ;
 tmp_time.tm_year = m_FrameInfo->nYear - 1900 ;
 m_FrameInfo->nTimeStamp = mktime(&tmp_time) ;

 

struct tm {
  int tm_sec;
  int tm_min;
  int tm_hour;
  int tm_mday;
  int tm_mon;
  int tm_year;
  int tm_wday;
  int tm_yday;
  int tm_isdst; /* 夏令时标识符,实行夏令时的时候,tm_isdst为正。不实行夏令时的进候,tm_isdst为0;不了解情况时,tm_isdst()为负。*/
  long int tm_gmtoff; /*指定了日期变更线东面时区中UTC东部时区正秒数或UTC西部时区的负秒数*/
  const char *tm_zone; /*当前时区的名字(与环境变量TZ有关)*/
};

当时没有初始化结构体,导致linux系统函数会去自动初始化,然后要找时区,夏令时能比较慢,

 后来 tm tmp_time ={0};直接初始化,再次看执行效果,显著提高了5倍以上。

 

总结 linux下面使用mktime时候,struct tm 定义变量时候先初始化。

 


 

最后

以上就是踏实马里奥为你收集整理的linux mktime很耗时的全部内容,希望文章能够帮你解决linux mktime很耗时所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(53)

评论列表共有 0 条评论

立即
投稿
返回
顶部