关于指针和数组
int ia[] = {0, 2, 4, 6, 8};
int i = ia[0]; // 在使用下标访问数组时,实际上是对指向数组元素的指针做下标操作????
// 对指针取下标直接就得到指针指向的值了????
int *p = &ia[2];
int *j = p[1]; // p[1] equivalent to *(p+1)????
// p[1] is the same element as ia[3] ????
int *k = p[-2]; // p[-2] is the same element as is[0] ???? 为什么是负的下标????
[解决办法]
int i = ia[0]; ==》 int i = *(ia+0)
int *j = p[1]; ==> int* j = *(p+1)
p[-2] ==> *(p-2)
[解决办法]
因为一开始指向的是ia+2的位置,想要访问ia[0]当然需要-2先。
[解决办法]
VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”
提醒:
“学习用汇编语言写程序”
和
“VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习C和汇编的对应关系。”
不是一回事!
不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
[解决办法]
int ia[] = {0, 2, 4, 6, 8};
int i = ia[0]; // 在使用下标访问数组时,实际上是对指向数组元素的指针做下标操作????
// 对指针取下标直接就得到指针指向的值了????
Answer: 是的,是对指向数组的指针做下标操作.因为下标操作要求其操作数一个是指针类型,另一个是整形,e1[e2]相当于 *(e1 + e2);
在你的例子中,ia是一个数组,数组可以转换成其首元素的指针,所以实际上这里是应用了这一个转换的.
int *p = &ia[2];
int *j = p[1]; // p[1] equivalent to *(p+1)????//yes,you are right;
// p[1] is the same element as ia[3] ????//yes ,you are right again;
int *k = p[-2]; // p[-2] is the same element as is[0] ???? 为什么是负的下标????要求是整形,没有规定一定是正的. 相当于 *(p - 2)
[解决办法]