单步调试,发现指针地址值没变不知道为什么?C/C++ codevoid CircleDelete::Delete_Node(struct Node * p){s
单步调试,发现指针地址值没变不知道为什么?
C/C++ codevoid CircleDelete::Delete_Node(struct Node * p){ struct Node * s = p; if(length == 2) { p->next->prior =p->next; p->next->next = p->next; } else { p->prior->next = p->next; p->next->prior = p->prior; } length--; if(length == 0) { cout<<"最后一个数字是"<<p->number<<endl; } p = p->next; delete s;}void CircleDelete::Delete_Circle(int m){ struct Node * p = head; //给 p 赋 头指针 if(length == 1) { cout<<"最后一个数字是"<<p->number<<endl; delete p; return ; } else while(length != 0) { for(int i=1;i<m;++i) p = p->next; if(length != 1) { Delete_Node(p); //第一次delete Delete_Node(p); //第二次delete } else break; } if(length == 1) cout<<"最后一个数字是"<<p->number<<endl; delete p;}
第一次delete时 p的地址为 0x00382698 也就是head(头指针)的地址
在Delete_Node()函数中,最好 p = p->next,查看地址为 0x003826e0
而在第二次delete时, p地址值却又变为 0x00382698,是原来的值,没变化,怎么搞的?我传给Delete_Node()函数的参数类型可是指针类型啊?函数中修改了他的值,为什么第一次delete后没变化呢?哪位大侠行行好,帮我看一下出了什么问题,谢谢!!!
[解决办法] 作用域的问题吗
[解决办法]如果要改变指针的地址,传递参数的时候用**
[解决办法]LS正解~~~
[解决办法][解决办法][解决办法]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、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!