如何解决使用Visual C++ 2008时未处理的异常错误?

问题描述:

在使用Visual C++ 2008时,有人能帮助我解决未处理的异常错误吗?错误显示为:在0x00411690在time.exe未处理的异常:0000005:访问冲突读取位置0x00000008如何解决使用Visual C++ 2008时未处理的异常错误?

一些细节:
- TM 00000000 {tm_sec = ??? tm_min = ??? tm_hour = ??? ...} TM *
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); 

} 

感谢您的答复:

+0

使用Visual Studio调试器,单步执行代码,并告诉我们在发生异常时... – Inverse 2010-03-22 07:01:58

+0

你在哪条线上得到这个例外......? – 2010-03-22 07:04:14

+0

感谢您的回复...请参阅以下行:tm-> tm_sec * 1000 + tv.tv_usec/1000); uint32_t stampstart()函数 – make 2010-03-22 07:11:54

与该地址,我的赃物是,TM为NULL。由于您在调用localtime()之后从不检查NULL,所以您正在取消引用NULL指针。

编辑:SWAG =科学野驴猜测。

地址0x00000008与tm.tm_hour的偏移量相同。当您将参数传递给printf()时,您试图访问tm-> tm_hour。

+0

哪个赃物你在说什么。 ..?我运行可执行文件时遇到错误。该程序编译和链接没有错误。但是当我执行它时,我得到未处理的异常......感谢回复! – make 2010-03-22 07:28:36

+0

“具体而驴猜”:)它会编译干净,因为编译器无法知道当你运行该程序时'tm'会结束null。直到你执行,这是不可能发生的。 – 2010-03-22 07:35:29

+0

感谢您的回复。实际上我没有Visual C++的经验,这是我第一次听说SWAG。所以请解释并告诉我如何使用来解决这个问题......再次感谢 – make 2010-03-22 14:09:49

访问冲突是指地址0x00000008,这可能意味着您的代码正在访问一个指向NULL指针的结构中偏移量为8的字段。 我想localtime返回一个空指针。检查这个。

+0

也许,但它为什么可以用VC++ 6而不是用VC++ 2008?感谢您的回复! – make 2010-03-22 07:43:20

“访问冲突读取位置0x00000008”

的地址低可能是通过访问一个空指针引起的。在这种情况下,由于localtimegettimeofday的问题,tm可能为0。你得到的地址是0x08而不是0x00,因为编译器试图在结构中读取8个字节的值。

+0

我认为这也是原因,但我需要阅读时间......感谢您的回复! – make 2010-03-22 07:41:46

尝试类似...

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 
} 
+0

感谢您的想法。是!它无法检索当地时间。有没有关于如何解决这个问题的想法?再次感谢您的帮助 – make 2010-03-22 07:40:14

+0

你可以看到errno的确切问题......如果localtime()失败,它将设置errno ... – 2010-03-22 09:13:29

+0

是的!它是本地时间,因为它不会返回任何想法。实际上我不明白它为什么可以用VC++ 6而不用VC++ 2008 ......谢谢! – make 2010-03-22 14:11:54

类型成员tv.tv_sec的是long,但localtime需要一个time_t *参数。在VC6中,这是因为longtime_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); 
+0

其实我已经试过了:tm = localtime((time_t *)&tv.tv_sec);并仍然得到相同的错误(异常处理)... – make 2010-03-22 19:30:56

+0

@make:我忘了这是C,所以变量必须在函数的开头声明。我编辑了我的答案来表明这一点。至于你的第二个评论,将它转换为'time_t *'将无济于事,因为它没有实际的'time_t'指向。 – interjay 2010-03-22 19:59:32

+0

谢谢!是的,你是对的,因为我回复你的信息后,我刚刚恢复正常,答案是肯定的。我也尝试了这一点,仍然得到相同的错误...任何其他想法...再次感谢您的帮助 – make 2010-03-22 20:03:44

捕捉这种例外的是需要一个小的项目调整。只需在项目设置中启用/ EHa选项。请参阅项目属性 - > C/C++ - >代码生成 - >将启用C++异常修改为“是有SEH异常”。而已!

查看详情这里: http://msdn.microsoft.com/en-us/library/1deeycx5(v=vs.80).aspx