我一直在经历K&R第二版的书和我一直在努力让其中一个例子正常运行。
直接取自书中第5章的代码(主要添加了一些随机变量(:
static char daytab[2][13] = {
{0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31},
{0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}
};
/* day_of_year: set day of year from month & day */
int day_of_year(int year, int month, int day)
{
int i, leap;
leap = year%4 == 0 && year%100 != 0 || year%400 == 0;
for (i = 1; i < month; i++)
day += daytab[leap][i];
return day;
}
/* month_day: set month, day from day of year */
void month_day(int year, int yearday, int *pmonth, int *pday)
{
int i, leap;
leap = year%4 == 0 && year%100 != 0 || year%400 == 0;
for (i = 1; yearday > daytab[leap][i]; i++)
yearday -= daytab[leap][i];
*pmonth = i;
*pday = yearday;
}
int main(){
int x = 5, y = 10;
int *q, *p;
month_day(x, y, q, p);
}
这个程序给了我分段错误,所以我试着在gdb中运行它。
我在month_day函数中设置了一个断点,一些事情立即引起了我的注意。
gdb显示pmmonth被初始化为某个地址,但pday被初始化为0x0。这不可能是正确的,我知道这一点,但首先是什么原因造成的?
这是month_day函数,其参数在gdb:中
month_day (year=5, yearday=10, pmonth=0x7fffffffe150, pday=0x0) at e5-8.c:19
正如预期的那样,当尝试打印*pmonth时,它可以正常工作,但打印*pday没有,因为它初始化为0x0。
gdb输出:
19 leap = year%4 == 0 && year%100 != 0 || year%400 == 0;
(gdb) print pday
$1 = (int *) 0x0
(gdb) print *pday
Cannot access memory at address 0x0
(gdb) print *pmonth
$2 = 1
这很可能是一个简单的解决方案,但我也想了解发生了什么!
您需要传递有效的地址。也许你只是想要:
int main(void){
int x = 5, y = 10;
int q, p;
month_day(x, y, &q, &p);
}