关于结构体以及内部指针的一道面试题

来源:互联网 发布:hash算法的实现原理 编辑:程序博客网 时间:2024/05/01 12:27

某公司的一道面试题,有个地方纠结了半天,可能是惯性思维的原因吧,最终还是没看出来T.T
找出下面程序运行错误的语句

struct S{    int i;    int *p;};int main(){    S s;    int *p = &s.i;    p[0] = 4;    p[1] = 3;    s.p = p;    s.p[1] = 1;    s.p[0] = 2;}

先很机械化的一行一行的分析一下吧,
S s; //定义一个s结构体,没什么错误
int *p = &s.i; //相当于int *p; p = &s.i;
p[0] = 4; //(p+0) = (&s.i) = s.i = 4;
p[1] = 3; //(p+1) = (&s.i+1) = s.p = 3;
s.p = p; // s.p = &s.i; s结构体内部的s.p指针指向了s.i;
s.p[1] = 1; //(s.p+1) = (&s.i+1) = *(&s.p) = s.p = 1;相当于s.p指向了0x00000001这个地址
s.p[0] = 2; // (s.p+0) = (1) = 2;试图修改了1这个地址的内容,发生段错误

分析到这里答案就很显然了,值得注意的是倒数第二行,*(&s.i+1)=*(&s.p)是正确的,而我之前就当成了*(&s.i+1) = *(s.p),可能因为s.i的下一个地址是s.p吧,所以就直接这样想了然后转化成了*(s.p) = *(&s.i) = s.i = 1,再也没看出哪里错了。

0 0
原创粉丝点击