概述
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很耗时所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复