指针的赋值不是很理解解决方案

指针的赋值不是很理解
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";
------解决方案--------------------
探讨

2楼5楼不是一个意思吗

------解决方案--------------------
探讨

destring = string;
destring指向string指向的字符串,他们两个指针均指向“1234567890”字符串的首地址。

------解决方案--------------------
探讨

main()
{
char * test_string = "12";

test_string[0] = 'd';

printf("%s",test_string);
getch();
}
这不就是写吗?

我对楼上几位说的常量区和非保护模式这俩概念之前没听过,估计是底层和PC之间的差异。

------解决方案--------------------
常量是不能被修改的。
至于赋值语句相当于两个指针指向了同一个字符串常量。
------解决方案--------------------
1234567890是个常量,放在内存中,相当于开辟了11个char大小的内存空间,最后一个是自动加上的'\0'

char* string是个指针,指针里面的内容是'1'这个字符所在的内存地址

memset(string, 0, 10),修改那10个常量,会出错

destring = string是将destring的内容也换成了'1'的地址

------解决方案--------------------
探讨
引用:
引用:

引用:
char *string = "1234567890";
destring = string;等同于destring = "1234567890";


这样说我就完全懂了
......那是错误描述,如果你懂了它,你就继续错了。



难道是string和destring共同指向de……