Segfault退出主要时

时间:2012-08-19 01:26:04

标签: c unix pointers operating-system segmentation-fault

我正在编写一个非常基本的C程序,试图更好地理解时间库的工作方式,并了解更多关于C.问题是,当我在主函数结束时返回0时,我得到一个段错误。这是该计划的文本:

#include <stdio.h>
#include <time.h>

main()
{
    time_t *now;
    time(now);
    struct tm *tp = localtime(now);
    printf("%s", asctime(tp));
    return 0;
}

使用gdb我可以看到第10行(返回0)到目前为止一切都很好,我现在只有两个变量和tp。以下是我打印时发生的情况:

(gdb) print now
$7 = (time_t *) 0x7fff5fbff838
(gdb) print tp
$8 = (struct tm *) 0x7fff7b13e470
(gdb) print *now
$9 = 1345338893
(gdb) print *tp
$10 = {
  tm_sec = 53, 
  tm_min = 14, 
  tm_hour = 21, 
  tm_mday = 18, 
  tm_mon = 7, 
  tm_year = 112, 
  tm_wday = 6, 
  tm_yday = 230, 
  tm_isdst = 1, 
  tm_gmtoff = -14400, 
  tm_zone = 0x100802518 "EDT"
}

一切似乎都很好。但是当我点击n时,

Cannot access memory at address 0x50303e0d
0x0000000050303e0d in ?? ()

我不明白可能导致此错误的原因。在main结束时返回0从来没有伤害过我,并且内存地址与我正在使用的任何一个都不匹配。当我在终端中运行我的程序时,我得到Segmentation fault: 11。 我唯一能想到的是它与操作系统有关,这有几个原因:相对较低的内存地址,以及O.S抛出的错误。试图访问堆栈上的内存地址返回。但为什么会这样呢?我对操作系统了解不多(我正在学习C语言,所以我可以跳过课程要求并参加我大学提供的操作系统课程)所以这可能是一个非常简单的问题。我尝试在同一个目录中运行另一个C程序,它就可以了。

1 个答案:

答案 0 :(得分:5)

你没有初始化now或者你想在堆栈上初始化它,比如

#include <stdio.h>
#include <time.h>

main()
{
    time_t now;
    time(&now);
    struct tm *tp = localtime(&now);
    printf("%s", asctime(tp));
    return 0;
}