您的位置:首页 > 其它

数组和指针

2012-01-08 15:46 281 查看
先上题:

int main()
{
int a[5] = {1,2,3,4,5};
int *ptr = (int *)(&a +1);
printf("%d", *(ptr-1));
return 0;
}
对于这道题,我的第一感觉是输出1,但是实际是输出5,为什么呢???

加一条打印语句,代码如下:

int main()
{
int a[5] = {1,2,3,4,5};
int *ptr = (int *)(&a +1);
printf("%X,%X\n",&a,&a+1);
printf("%d\n", *(ptr-1));
return 0;
}
输出&a和&a+1,就可以知道当前ptr实际指向a[5]的位置(数组a实际只有5个数)而不是a[0]位置。我们可以打印看看:

#include <stdio.h>
#include <stdlib.h>

int main()
{
int a[5] = {1,2,3,4,5};
int *ptr = (int *)(&a +1);
printf("%d\n",*ptr);
printf("%d", *(ptr-1));
return 0;
}

上一个程序打印*ptr是乱码,下一段代码打印ptr是100。建议将下面程序的数组a设置成全局变量,而不是局部变量。因为局部变量是在栈里面的,栈用于保存函数的局部变量和函数调用的环境变量,所以对栈内的没分配的空间乱调用也许会造成程序运行混乱。但是全局变量是在堆里分配的。

#include <stdio.h>
#include <stdlib.h>
int a[5] = {1,2,3,4,5};
int main()
{
int *ptr = (int *)(&a +1);
a[5]=100;
printf("%d\n",*ptr);
printf("%d", *(ptr-1));
return 0;
}
这道题的关键在于理清&a的类型是in*,还是int*[5]。

下面还有几个类似的:

#include <stdio.h>
#include <stdlib.h>

typedef int y[5];
int main()
{
int a[5] = {1,2,3,4,5};
y *ptr = &a + 1;
printf("%X\n",a);
printf("%X\n",&a);
printf("%X\n",&a+1);
printf("%X\n",ptr);
printf("%X\n",ptr-1);
printf("%d", *((int*)(ptr-1)));
return 0;
}


#include <stdio.h>
#include <stdlib.h>

typedef int y[5];

int main()
{
int a[5] = {1,2,3,4,5};
y *ptr = &a + 1;
printf("%X\n",a);
printf("%X\n",&a);
printf("%X\n",&a+1);
printf("%X\n",ptr);
printf("%X\n",ptr-1);
printf("%d\n", *((int*)(ptr-1)));
printf("%X\n",&a);
printf("%X\n",*(&a));
return 0;
}
#include <stdio.h>
#include <stdlib.h>

typedef int y[5];

int main()
{
int a[5] = {1,2,3,4,5};
y *ptr = &a + 1;
printf("%X\n",a);
printf("%X\n",&a);
printf("%X\n",&a+1);
printf("%X\n",ptr);
printf("%X\n",ptr-1);
printf("%d\n", *((int*)(ptr-1)));
printf("%X\n",&a);
printf("%X\n",*(&a));
printf("%X\n",*(*(&a)));
return 0;
}


#include <stdio.h>
#include <stdlib.h>

typedef int y[5];

int main()
{
int a[5] = {1,2,3,4,5};
y *ptr = &a + 1;
printf("%X\n",a);
printf("%X\n",&a);
printf("%X\n",&a+1);
printf("%X\n",ptr);
printf("%X\n",ptr-1);
printf("%d\n",*(*(ptr-1)));
printf("%d\n", *((int*)(ptr-1)));
printf("%X\n",&a);
printf("%X\n",*(&a));
printf("%X\n",*(*(&a)));
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: