Как использовать gettimeofday() или что-то эквивалентное с Visual Studio C++ 2008?
Может кто-нибудь помочь мне использовать функцию gettimeofday() с Visual Studio C++ 2008 на Windows XP? Вот код, который я нашел где-то в сети:
#include < time.h >
#include <windows.h>
#if defined(_MSC_VER) || defined(_MSC_EXTENSIONS)
#define DELTA_EPOCH_IN_MICROSECS 11644473600000000Ui64
#else
#define DELTA_EPOCH_IN_MICROSECS 11644473600000000ULL
#endif
struct timezone
{
int tz_minuteswest; /* minutes W of Greenwich */
int tz_dsttime; /* type of dst correction */
};
int gettimeofday(struct timeval *tv, struct timezone *tz)
{
FILETIME ft;
unsigned __int64 tmpres = 0;
static int tzflag;
if (NULL != tv)
{
GetSystemTimeAsFileTime(&ft);
tmpres |= ft.dwHighDateTime;
tmpres <<= 32;
tmpres |= ft.dwLowDateTime;
/*converting file time to unix epoch*/
tmpres -= DELTA_EPOCH_IN_MICROSECS;
tmpres /= 10; /*convert into microseconds*/
tv->tv_sec = (long)(tmpres / 1000000UL);
tv->tv_usec = (long)(tmpres % 1000000UL);
}
if (NULL != tz)
{
if (!tzflag)
{
_tzset();
tzflag++;
}
tz->tz_minuteswest = _timezone / 60;
tz->tz_dsttime = _daylight;
}
return 0;
}
...
// call gettimeofday()
gettimeofday(&tv, &tz);
tm = localtime(&tv.tv_sec);
В прошлом году, когда я тестировал этот код с VC++6, он работал нормально. Но теперь, когда я использую VC++ 2008, я получаю ошибку обработки исключений. Так есть ли идеи о том, как использовать gettimeofday или что-то подобное?
Спасибо за ваш ответ, и любая помощь будет принята с благодарностью:
3 ответа
В UNIX использование структуры часовых поясов устарело. Я не знаю, почему вы используете это. См. http://linux.about.com/od/commands/l/blcmdl2_gettime.htm Но если вы хотите использовать эту структуру, чтобы узнать разницу по Гринвичу (UTC) по местному времени, она будет следующей: tz_minuteswest - реальная разница в минутах от GMT(UTC) и tz_dsttime - флаг, указывающий, используется ли дневной свет в настоящее время.
Ваш пример с некоторыми изменениями прекрасно работает в Visual C++ 2008 Express:
#include "stdafx.h"
#include <time.h>
#include <windows.h>
const __int64 DELTA_EPOCH_IN_MICROSECS= 11644473600000000;
/* IN UNIX the use of the timezone struct is obsolete;
I don't know why you use it. See http://linux.about.com/od/commands/l/blcmdl2_gettime.htm
But if you want to use this structure to know about GMT(UTC) diffrence from your local time
it will be next: tz_minuteswest is the real diffrence in minutes from GMT(UTC) and a tz_dsttime is a flag
indicates whether daylight is now in use
*/
struct timezone2
{
__int32 tz_minuteswest; /* minutes W of Greenwich */
bool tz_dsttime; /* type of dst correction */
};
struct timeval2 {
__int32 tv_sec; /* seconds */
__int32 tv_usec; /* microseconds */
};
int gettimeofday(struct timeval2 *tv/*in*/, struct timezone2 *tz/*in*/)
{
FILETIME ft;
__int64 tmpres = 0;
TIME_ZONE_INFORMATION tz_winapi;
int rez=0;
ZeroMemory(&ft,sizeof(ft));
ZeroMemory(&tz_winapi,sizeof(tz_winapi));
GetSystemTimeAsFileTime(&ft);
tmpres = ft.dwHighDateTime;
tmpres <<= 32;
tmpres |= ft.dwLowDateTime;
/*converting file time to unix epoch*/
tmpres /= 10; /*convert into microseconds*/
tmpres -= DELTA_EPOCH_IN_MICROSECS;
tv->tv_sec = (__int32)(tmpres*0.000001);
tv->tv_usec =(tmpres%1000000);
//_tzset(),don't work properly, so we use GetTimeZoneInformation
rez=GetTimeZoneInformation(&tz_winapi);
tz->tz_dsttime=(rez==2)?true:false;
tz->tz_minuteswest = tz_winapi.Bias + ((rez==2)?tz_winapi.DaylightBias:0);
return 0;
}
int _tmain(int argc, _TCHAR* argv[])
{
struct timeval2 tv;
struct timezone2 tz;
struct tm *tm1;
time_t time1;
ZeroMemory(&tv,sizeof(tv));
ZeroMemory(&tz,sizeof(tz));
gettimeofday(&tv, &tz); // call gettimeofday()
time1=tv.tv_sec;
tm1 = localtime(&time1);
FILE *f;
f=fopen("rez.txt","w");
fprintf(f,"%04d.%02d.%02d %02d:%02d:%02d\n",1900+tm1->tm_year,1+tm1->tm_mon,tm1->tm_mday,tm1->tm_hour,tm1->tm_min,tm1->tm_sec);
fprintf(f,"Diffrence between GMT(UTC) and local time=%d %s\n",tz.tz_minuteswest,"minutes");
fprintf(f,"Is Daylight now=%s\n",tz.tz_dsttime?"Yes":"No");
fclose(f);
return 0;
}
Простой секундомер за секунды
FWIW: Это то же самое, что и у Кейт, но я просто хотел упомянуть об этом, если кто-то ищет самый простой секундомер в C++ (считая секунды). Не беда, я знаю. Он имеет разрешение всего 1 с, поэтому, если вы хотите создать микросек, перейдите к другим примерам.
double seconds=0;
time_t timer1, timer2;
time(&timer1); /* get current time */
...
time(&timer2); /* get current time later */
seconds = difftime(timer2,timer1);
Есть несколько разных типов для представления времени. Вот код, который я недавно использовал:
time_t now;
tm* local;
time(&now);
local=localtime(&now);
Затем я продолжил строить строку из кусочков local
, но вы могли бы сделать то, что вы хотели в этот момент.
Кейт
В моем случае это работало следующим образом: Поскольку я хотел найти среднее время работы, я использовал: Сначала включить в начало программы, затем: инициализировать образцы =100 (например);
time_t t_start,t_end;
time(&t_start); //get the current time
//program that needs to be timed
time(&t_end); //get the time at the end of execution of the program
seconds = (difftime(t_start,t_end))/samples;//calculate the difference