调用系统时间与获得程序运行时间方法

time_t time(time_t *timer);
调用后将当前系统时间与1900年1月1日相差的秒数存入到timer中,timer可看成是一个长整型数
struct tm* localtime(const time_t *timer)
将time()函数调用的结果做为参数传入到localtime()函数中就能得到当前时间和日期,注意得到的年是和1970的差值,月份是和1月的差值
struct tm是一个结构体,定义如下
struct tm
{
int tm_sec;    //当前秒
int tm_min;    //当前分钟
int tm_hour;   //当前小时
int tm_mday;   //当前在本月中的天,如11月1日,则为1
int tm_mon;    //当前月,范围是0~11
int tm_year;   //当前年和1900的差值,如2006年则为36
int tm_wday;   //当前在本星期中的天,范围0~6
int tm_yday;   //当前在本年中的天,范围0~365
int tm_isdst;  //这个我也不清楚
}

求当前时间的示例
int getSystemTime()
{
    time_t timer;
    struct tm* t_tm;
    time(&timer);
    t_tm = localtime(&timer);
    printf("today is %4d%02d%02d%02d%02d%02d/n", t_tm.tm_year+1900,
         t_tm.tm_mon+1, t_tm.tm_mday, t_tm.tm_hour, t_tm.tm_min, t_tm.tm_sec);
    return 0;
}

其他时间的函数和结构还有:
timeval结构
#include <include/linux/time.h>

struct timeval
{
       time_t     tv_sec;
       susecond_t     tv_usec;         //当前妙内的微妙数
};

tms结构
保存着一个进程及其子进程使用的cpu时间

struct tms
{
clock_t tms_utime;
clock_t tms_stime;
clock_t tms_cutime;
clock_t tms_cstime;
}

timer_struct结构
#include <include/linux/timer.h>

struct timer_struct
{
       unsigned long expires;    //定时器被激活的时刻
       void (*fn)(void);           //定时器激活后的处理函数
}

utime函数
更改文件的存取和修改时间

int utime(const char pathname, const struct utimbuf *times)                    // return value 0 or -1

times 为空指针,存取和修改时间设置为当前时间

struct utimbuf
{
       time_t     actime;
       time_t     modtime;

}

//***************************获得当前时间范例[START]*********************************************//

struct tm *newtime;
 char am_pm[] = "AM";
 time_t long_time;

 time( &long_time );                /* Get time as long integer. */
 newtime = localtime( &long_time ); /* Convert to local time. */

 if( newtime->tm_hour > 12 )        /* Set up extension. */
  strcpy( am_pm, "PM" );
 if( newtime->tm_hour > 12 )        /* Convert from 24-hour */
  newtime->tm_hour -= 12;    /*   to 12-hour clock.  */
 if( newtime->tm_hour == 0 )        /*Set hour to 12 if midnight. */
  newtime->tm_hour = 12;

 printf( "%.19s %s/n", asctime( newtime ), am_pm );

//******************************获得当前时间范例[END]******************************************//

 

 

//*********************获得代码段运行时间程序片段************************************************//
#include<iostream>
#include<windows.h>

int main()
{
DWORD start_time=GetTickCount();
{
//此处为被测试代码
}
DWORD end_time=GetTickCount();
cout<<"The run time is:"<<(end_time-start_time)<<"ms!"<<endl;//输出运行时间
return 0;
}                  

GetTickCount函数返回从系统运行到现在所经历的时间(类型为DWORD),单位为ms,因为DWORD表示范围的限制,所以使用此种方法存在限制,即系统的运行时间的ms表示不能超出DWORD的表示范围。

第二种:使用clock()函数 
#include<iostream>
#include<time.h>

int main()
{
clock_t start_time=clock();

{
//被测试代码
}

clock_t end_time=clock();
cout<< "Running time is: "<<static_cast<double>(end_time-start_time)/CLOCKS_PER_SEC*1000<<"ms"<<endl;//输出运行时间
return 0;
} clock_t,clock()定义于time.h中,clock()返回从程序运行时刻开始的时钟周期数,类型为long.CLOCKS_PER_SEC定义了每秒钟包含多少了时钟单元数,因为计算ms,所以*1000。
//********************************************************************************************//

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值