Как решить необработанную ошибку исключения при использовании Visual C ++ 2008? - PullRequest
2 голосов
/ 22 марта 2010

Может кто-нибудь помочь мне решить проблему необработанного исключения при использовании Visual C ++ 2008? ошибка отображается следующим образом: необработанное исключение в 0x00411690 в time.exe: 0xC0000005: место чтения нарушения доступа 0x00000008

Некоторые детали:
- tm 0x00000000 {tm_sec = ??? tm_min = ??? tm_hour = ??? ...} тм *
tm_sec CXX0030: ошибка: выражение не может быть оценено
...

На самом деле, когда я использовал Visual C ++ 6 в прошлом, ошибок не было, и программа работала нормально. Но теперь, когда я использую Visual 2008, я получаю эту ошибку необработанного исключения.

Вот программа:

...
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);

}

спасибо за ваши ответы:

Ответы [ 6 ]

2 голосов
/ 22 марта 2010

Попробуйте что-то вроде ...

 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
}
1 голос
/ 22 марта 2010

Тип члена 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);
1 голос
/ 22 марта 2010

"Место чтения нарушения доступа 0x00000008"

Низкий адрес, вероятно, вызван доступом к нулевому указателю.В этом случае tm вероятно равно 0 из-за проблемы с localtime или gettimeofday.Вы получаете адрес 0x08 вместо 0x00, потому что компилятор пытается прочитать значение 8 байтов в структуре.

1 голос
/ 22 марта 2010

Нарушение доступа относится к адресу 0x00000008, что, вероятно, означает, что ваш код обращается к полю со смещением 8 в структуре, на которую вы указываете с указателем NULL. Я предполагаю, что localtime возвращает нулевой указатель. Проверьте это.

0 голосов
/ 23 ноября 2011

Чтобы поймать это исключение, требуется небольшая настройка проекта. Просто включите опцию / EHa в настройках проекта. См. Свойства проекта -> C / C ++ -> Генерация кода -> Установите для параметра Разрешить исключения C ++ значение «Да с исключениями SEH» . Вот и все!

Подробности здесь: http://msdn.microsoft.com/en-us/library/1deeycx5(v=vs.80).aspx

0 голосов
/ 22 марта 2010

С этим адресом моя SWAG - это тм NULL. Поскольку вы никогда не проверяете NULL после вызова localtime (), вы разыменовываете указатель NULL.

Редактировать: SWAG = Научный догадка дикой задницы.

Адрес 0x00000008 является таким же смещением tm.tm_hour. Вы пытаетесь получить доступ к tm-> tm_hour при передаче параметра в printf ().

...