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 定义变量时候先初始化。

 


 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值