关于指针加减的一道题目
来源:互联网 发布:js window.event对象 编辑:程序博客网 时间:2024/05/18 00:29
考查指针的题目,这道题只适合于那些特别细心且对指针和数组有深入理解的人
main() { int a[5] = {1,2,3,4,5}; int *ptr = (int*)(&a+1); printf("%d %d" , *(a+1),*(ptr-1) );}
这段程序的输出是:
(a) 2 2
(b) 2 1
(c) 2 5
(d) 以上均不是
答案就是C,怎么分析呢,我不多说,直接看VC中的测试
这是代码
#include <stdio.h> int main(int argc, char * argv[]){ inta[5] = {1,2,3,4,5}; int*ptr = (int *)(&a + 1); printf("aaddr 0x%x\n", a); printf("a+1addr 0x%x\n", a+1); printf("a[0]addr 0x%x\n",&a[0]); printf("a[1]addr 0x%x\n",&a[1]); printf("a[2]addr 0x%x\n",&a[2]); printf("a[3]addr 0x%x\n",&a[3]); printf("a[4]addr 0x%x\n",&a[4]); printf("&a+1 addr 0x%x\n", &a+1); printf("ptraddr 0x%x\n",ptr); printf("ptr-1 addr 0x%x\n",ptr-1); printf("%d,%d\n",*(a+1),*(ptr - 1)); return0;}
输出结果是:
a addr 0x12ff6c
a+1 addr 0x12ff70
a[0] addr 0x12ff6c
a[1] addr 0x12ff70
a[2] addr 0x12ff74
a[3] addr 0x12ff78
a[4] addr 0x12ff7c
&a +1 addr 0x12ff80
ptr addr 0x12ff80
ptr -1 addr 0x12ff7c
2, 5
是不是就理解答案了呢.如果不能正解就向下看
这里要说明就是指针的加减问题
在谭老书中其实有说明的(10.8.2指针运算小结),说实话,谭老的书什么时候都不能扔呀
C语言规定,一个指针变量加减一个整数,并不是简单的将指针变量的原值加减一个整数,而是将该指针变量的原值(是一个地址)和它指向的变量所占用的内存单元字节数想加减
那么在本例中:
&a+1相当于0x12ff6c+0x14(20个字节,第个int型的数占4个字节,数组有5个整型),即0x12ff80;
而a+1相当于0x12ff6c+0x4,即0x12ff70;那么*(a+1)就等同于a[1];
Ptr的值呢就0x12ff80了,ptr-1呢就是0x12ff80-0x4了,即0x12ff7c.那么*(ptr-1)就等同于a[4]
所以结果是2,5
- 关于指针加减的一道题目
- 一道关于编译和指针的题目
- 一道关于虚函数指针的题目
- 关于指针的加减
- 20080306:上海华为的一道关于指针的编程题目
- 一道关于二维数组与指针的题目
- 关于指针的加减操作
- 关于继承的一道题目
- 一道关于排序的题目
- 关于fork的一道题目
- 一道关于继承的题目
- 关于指针的加减操作的理解
- 一道指针相关题目的跟踪
- C++指针加减-题目分析
- 一道指针题目
- 一道关于二维数组和指针数组的C语言笔试题目
- 好文摘抄 [C语言]关于指针和int型的一道题目
- 笔试的一道关于测试的题目
- 有向图的强连通分量的三个算法
- 腾讯面试C语言题
- 【GamePlay3D】开发——范例解读之MeshGame
- Hadoop管理员的十个最佳实践(转)
- 杭电2034
- 关于指针加减的一道题目
- Kerberos原理--经典对话
- 对kerberos的理解--经典对话读后
- dwr 整合时报错
- 杭电2035
- 函数模板 Function Template(C++Primer-10)
- POJ 3189 Steady Cow Assignment (枚举+二分图的多重匹配)
- 黑马程序员_多线程
- GL和DX中关于纹理操作(包括多重纹理)与混合的问题