Как решить необработанную ошибку исключения при использовании Visual С++ 2008?
Может ли кто-нибудь помочь мне решить необработанную ошибку исключения при использовании Visual С++ 2008? ошибка отображается следующим образом: Необработанное исключение в 0x00411690 в time.exe: 0xC0000005: Место для обнаружения нарушения доступа 0x00000008
Некоторые детали:
- tm 0x00000000 {tm_sec =??? tm_min =??? tm_hour =???...} tm *
tm_sec CXX0030: Ошибка: выражение не может быть оценено
...
Фактически, когда я использовал visual С++ 6 в прошлом, ошибок не было и программа работала нормально. Но теперь, когда я использую visual 2008, я получаю эту ошибку Unhandled exception.
Вот программа:
...
int gettimeofday(struct timeval *tv, struct timezone *tz)
{
FILETIME ft;
unsigned __int64 tmpres = 0;
static int tzflag = 0;
if (NULL != tv)
{
GetSystemTimeAsFileTime(&ft);
tmpres |= ft.dwHighDateTime;
tmpres <<= 32;
tmpres |= ft.dwLowDateTime;
tmpres /= 10; /*convert into microseconds*/
/*converting file time to unix epoch*/
tmpres -= DELTA_EPOCH_IN_MICROSECS;
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;
}
uint32_t stampstart()
{
struct timeval tv;
struct timezone tz;
struct tm *tm;
uint32_t start;
gettimeofday(&tv, &tz);
tm = localtime(&tv.tv_sec);
printf("TIMESTAMP-START\t %d:%02d:%02d:%d (~%d ms)\n", tm->tm_hour,
tm->tm_min, tm->tm_sec, tv.tv_usec,
tm->tm_hour * 3600 * 1000 + tm->tm_min * 60 * 1000 +
tm->tm_sec * 1000 + tv.tv_usec / 1000); /////---debugger stops here---
start = tm->tm_hour * 3600 * 1000 + tm->tm_min * 60 * 1000 +
tm->tm_sec * 1000 + tv.tv_usec / 1000;
return (start);
}
спасибо за ваши ответы:
Ответы
Ответ 1
Попробуйте что-то вроде...
tm = localtime(&tv.tv_sec);
if(tm)
{
printf("TIMESTAMP-START\t %d:%02d:%02d:%d (~%d ms)\n", tm->tm_hour,
tm->tm_min, tm->tm_sec, tv.tv_usec,
tm->tm_hour * 3600 * 1000 + tm->tm_min * 60 * 1000 +
tm->tm_sec * 1000 + tv.tv_usec / 1000);
start = tm->tm_hour * 3600 * 1000 + tm->tm_min * 60 * 1000 +
tm->tm_sec * 1000 + tv.tv_usec / 1000;
}
else
{
// failed to retrive local time
}
Ответ 2
Нарушение доступа относится к адресу 0x00000008, что, вероятно, означает, что ваш код обращается к полю со смещением 8 в структуре, к которой вы указываете указатель NULL.
Я предполагаю, что localtime возвращает указатель NULL. Проверьте это.
Ответ 3
"Доступ к считыванию нарушений доступа 0x00000008"
Низкий адрес, вероятно, вызван доступом к нулевому указателю. В этом случае tm
, вероятно, 0 из-за проблемы с localtime
или gettimeofday
. Вы получаете адрес 0x08 вместо 0x00, потому что компилятор пытается прочитать значение 8 байтов в структуре.
Ответ 4
Тип члена tv.tv_sec
равен long
, но localtime
ожидает параметр time_t *
. В VC6 это работало, потому что оба long
и time_t
были 32-битными, но в VS2008 time_t
является 64-разрядным типом, поэтому они несовместимы.
Это должно исправить:
//add to beginning of stampstart function:
time_t t;
//... other code...
//put this instead of call to localtime:
t = tv.tv_sec;
tm = localtime(&t);
Ответ 5
С этим адресом мой SWAG - это tm NULL. Поскольку вы никогда не проверяете NULL после вызова localtime(), вы разыскиваете указатель NULL.
Изменить: SWAG = Научная дикая жопа Угадайте.
Адрес 0x00000008 - это то же самое смещение tm.tm_hour. Вы пытаетесь получить доступ к tm- > tm_hour, когда вы передаете параметр printf().
Ответ 6
Чтобы поймать такое исключение, необходима небольшая настройка проекта. Просто включите /EHa в настройках проекта. См. Свойства проекта → C/С++ → Генерация кода → Измените Исключительные исключения С++ на "Да с исключениями SEH" . Что это!
Подробнее см. здесь:
http://msdn.microsoft.com/en-us/library/1deeycx5 (v = vs .80).aspx