socket接收汉字问题
Java端为客户端,c语言的服务端,客户端通过socket发送带有汉字的字符串,服务端接收,为什么接收到的汉字是乱码,无论是一个字节一个字节的接收还是用一个buff一起接...
Java端为客户端,c语言的服务端,客户端通过socket发送带有汉字的字符串,服务端接收,为什么接收到的汉字是乱码,无论是一个字节一个字节的接收还是用一个buff一起接收都是乱码,
char rcvbuf[256];
memset(rcvbuf,0x00,sizeof(rcvbuf));
..
iRet = recv(nfp, rcvbuf, 1, MSG_DONTWAIT);
.. 展开
char rcvbuf[256];
memset(rcvbuf,0x00,sizeof(rcvbuf));
..
iRet = recv(nfp, rcvbuf, 1, MSG_DONTWAIT);
.. 展开
4个回答
展开全部
1. C/C++默认用 GBK 编码,GBK汉字点二个字节,java 端也要用GBK,java UTF-8 点三个字节
2、C++ 网络字节序是大端,java是小端,所以java需要转换一下
如java端int型转换成大端字节序:
private byte[] liob(int n)
{
byte[] b = new byte[4];
b[0] = (byte) (n & 0xff);
b[1] = (byte) (n >> 8 & 0xff);
b[2] = (byte) (n >> 16 & 0xff);
b[3] = (byte) (n >> 24 & 0xff);
return b;
}
2、C++ 网络字节序是大端,java是小端,所以java需要转换一下
如java端int型转换成大端字节序:
private byte[] liob(int n)
{
byte[] b = new byte[4];
b[0] = (byte) (n & 0xff);
b[1] = (byte) (n >> 8 & 0xff);
b[2] = (byte) (n >> 16 & 0xff);
b[3] = (byte) (n >> 24 & 0xff);
return b;
}
追问
第一点是明白了,第二点大端小端是什么意思啊 ........ 谢谢
追答
通常我们认为,在空中传输的字节的顺序即网络字节序为标准顺序,考虑到与协议的一致以及与同类其它平台产品的互通,在程序中发数据包时,将主机字节序转换为网络字节序,收数据包处将网络字节序转换为主机字节序。网络字节顺序是TCP/IP中规定好的一种数据表示格式,它与具体的CPU类型、操作系统等无关,从而可以保证数据在不同主机之间传输时能够被正确解释。网络字节顺序采用big endian排序方式。
例子:在内存中双字0x01020304(DWORD)的存储方式
内存地址
4000 4001 4002 4003
小端:LE 04 03 02 01
大端:BE 01 02 03 04
补充:无论是大端到小端,还是小端到大端,只要是大于一个字节的,就要转换。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
客户端和服务端字符编码统一下,试下吧,最好两边全是UTF-8
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
首先要收发的字符编码要一样,比如都是utf8的。
然后要保证数据编码要一样,比如都是 big-end的。
才能进行通信
然后要保证数据编码要一样,比如都是 big-end的。
才能进行通信
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询