指针偏移量,请一上

指针偏移量,请高手指点一下
C/C++ code

char *content = NULL;
content = (char*)(Buf+16);



问题是,Buf也是一个char *,我要从Buf中取得content,但取的时候总是要多取一位,比如正常的应该是“你好!”,取出来的却是“你好!e”,这个e是后面一位的,这个问题该怎么解决呢?谢谢大家

------解决方案--------------------
取指针的内容不是这样取的。
应该用一块新的内存来取。
如果是字符串用strcpy。
如果是数据,那么就用memcpy。
-
另外楼主如果用之前那块内存,那么用指针偏移是可以的。
但是楼主说取出的数据多了一个e。估计是没有在“你好!”加入结束符,字符串是\0结束的。
------解决方案--------------------
中文字符问题

用宽字符表示把
------解决方案--------------------
同意楼上说的
你可能还要注意一下要取的数据的长度,中文字符长度和英文和符号的长度看编码的情况会有所不同,所以调用strlen,wstrlen再去取数据的时候可能有问题
------解决方案--------------------
strcpy很容易实现,或者写个循环,一个字符一个字符的写入
复制整个字符串
while(*Buf!='\0')
{
*content=*Buf;
++content;
++Buf;
}

------解决方案--------------------
推荐使用WinHex软件查看文件或内存中的原始字节内容。

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、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!

------解决方案--------------------
你都知道多取了一位 少取一位不就行了
------解决方案--------------------
gbk or utf8?