指针的赋值不是很理解解决方案
指针的赋值不是很理解
main()
{
char *string = "1234567890";
char *destring;
char buf1[] ="ab";
char buf2[] ="cd";
memset(string,0,sizeof(string)) ;
destring = string; //这条语句怎么理解???
destring +=sprintf(destring,"%s:%s",buf1,buf2);
printf("%s",string);
getch();
}
//本以为输出会是 memset(string,0,sizeof(string)) ;这个结果,没想到是sprintf(destring,"%s:%s",buf1,buf2);
的执行结果,应该是这条语句destring = string;我没看明白,请指点
------解决方案--------------------
将 destring 赋予 string的值.
于是, destring和 string同时指向 一个匿名数组.
但是,那个数组"0123456789"是只读的,所以,给他 memset可能会发生悲剧
------解决方案--------------------
使destring指向string所指位置。
不过这个程序在前一条语句就会崩溃了。
------解决方案--------------------
memset(string,0,sizeof(string)) ;//你确定这句不会报ACCESS EOORR等问题??VS会报错。
destring = string; //这条语句怎么理解???这句话是将指针destring指向string。还有就是命名的时候最好不要用string。因为C++中有一个类是string
------解决方案--------------------
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、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
不要写连自己也预测不了结果的代码!
------解决方案--------------------
char *string = "1234567890";
destring = string;等同于destring = "1234567890";
------解决方案--------------------
------解决方案--------------------
------解决方案--------------------
------解决方案--------------------
常量是不能被修改的。
至于赋值语句相当于两个指针指向了同一个字符串常量。
------解决方案--------------------
1234567890是个常量,放在内存中,相当于开辟了11个char大小的内存空间,最后一个是自动加上的'\0'
char* string是个指针,指针里面的内容是'1'这个字符所在的内存地址
memset(string, 0, 10),修改那10个常量,会出错
destring = string是将destring的内容也换成了'1'的地址
------解决方案--------------------
main()
{
char *string = "1234567890";
char *destring;
char buf1[] ="ab";
char buf2[] ="cd";
memset(string,0,sizeof(string)) ;
destring = string; //这条语句怎么理解???
destring +=sprintf(destring,"%s:%s",buf1,buf2);
printf("%s",string);
getch();
}
//本以为输出会是 memset(string,0,sizeof(string)) ;这个结果,没想到是sprintf(destring,"%s:%s",buf1,buf2);
的执行结果,应该是这条语句destring = string;我没看明白,请指点
------解决方案--------------------
将 destring 赋予 string的值.
于是, destring和 string同时指向 一个匿名数组.
但是,那个数组"0123456789"是只读的,所以,给他 memset可能会发生悲剧
------解决方案--------------------
使destring指向string所指位置。
不过这个程序在前一条语句就会崩溃了。
------解决方案--------------------
memset(string,0,sizeof(string)) ;//你确定这句不会报ACCESS EOORR等问题??VS会报错。
destring = string; //这条语句怎么理解???这句话是将指针destring指向string。还有就是命名的时候最好不要用string。因为C++中有一个类是string
------解决方案--------------------
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、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
不要写连自己也预测不了结果的代码!
------解决方案--------------------
char *string = "1234567890";
destring = string;等同于destring = "1234567890";
------解决方案--------------------
------解决方案--------------------
------解决方案--------------------
------解决方案--------------------
常量是不能被修改的。
至于赋值语句相当于两个指针指向了同一个字符串常量。
------解决方案--------------------
1234567890是个常量,放在内存中,相当于开辟了11个char大小的内存空间,最后一个是自动加上的'\0'
char* string是个指针,指针里面的内容是'1'这个字符所在的内存地址
memset(string, 0, 10),修改那10个常量,会出错
destring = string是将destring的内容也换成了'1'的地址
------解决方案--------------------