日期:2014-05-16  浏览次数:20601 次

提个基础的,又很重要的问题(c,c++)
很多时候,我在用malloc(new)申请二进制内存的时候,类型用的是char,从而得到的指针是char*类型的。但最近研究协议相关的一些东西。发现网络上传送的包在系统中是存放在u_char*类型指针所指向的内存中的。那么问题出现了:为什么要用unsigned   char   类型的内存?所指空间存放什么数据的情况下将(unsigned   char   *)   转化成(char*)会发生问题?最好能举个例子,先谢了。

------解决方案--------------------
是的,我也有同样的疑惑!
比如send(),参数就是unsigned char*
为什么不用char*呢?

------解决方案--------------------
二进制的时候使用unsigned ,文本用char
------解决方案--------------------
2者其实没有区别
如果数据中高位是有效的数字位,就用unsigned char的形式处理数据,一般二进制发送数据都是用这个方式,二端都用。

如果高位只表示符号,没什么实在含义,就用char。

不过因为它们在内存中没有什么区别,当你强制转换它们的时候,它们就按照强制转换后的含义来表示数据。这就看应用的需要了。

没有什么大问题吧
------解决方案--------------------
unsigned char 和char的区别?
char 范围为-128 - 127
unsigned char 范围为
0-255
都是1字节