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内容请搜索靠谱客的其他文章。
发表评论 取消回复