我正在编写一个非常基本的C程序,试图更好地理解时间库是如何工作的,并了解更多关于C的信息。问题是,当我在主函数末尾返回0时,会出现segfault。这是程序的文本:
#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)看到到目前为止一切都很好,我仅有的两个变量是now和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程序,结果运行得很好。
您没有初始化now
,或者您可能想在堆栈上初始化它,比如
#include <stdio.h>
#include <time.h>
main()
{
time_t now;
time(&now);
struct tm *tp = localtime(&now);
printf("%s", asctime(tp));
return 0;
}