之前有学习过系统的大小端问题。还在网上找了很多资料学习。这次又碰到了,而且还让我找了良久。
这次的问题是这样的。在tcp传输中,有两个中文字符使用unsigned short[4],传输。.
typedef struct test
{
unsigned short GB[4] ;
}
然后在系统中。要输出中文格式。
系统为什么有大小端问题。就是应该有高低位系统的问题。
在windows系统和linux,ios系统中,每个系统处理高低位应该都会不一样。
然后我在网上找了很多文章,关于unsigned short[]如何转为 char []的问题。网上是说直接强制转换就可以了。
其实这是不对的。因为在强制转化的过程中,使用memcpy的方法的时候,他会考虑从高位复制还是低位复制。
在short转为char的时候,就是从多字节转化为单字节,在这里,需要多多注意。
char bg[8];
for(int j=0; j<4; ++j)
{
GB[j] = htons(GB[j]);
}
memcpy(bg, GB, 8);
这个转化过程需要先通过字节序的转化,然后在复制,这样得到的char *通过转化为gbk,utf-8这种格式,那么数据就能正常显示。
ps:所以说,不管short,double,float,int等类型不管是以何种方式展示的,都是需要字节序转化的。
所以说,其实高地位和大小端都是同一个性质的。系统大小端的判断方法(http://www.cnblogs.com/zhoug2020/p/3859761.html)
#include<stdio.h>
#include<stdlib.h>
int main()
{
int i = 1;
(*(char *)&i == 1) ? printf("Little-endian/n") : printf("Big-endian/n");
system("pause");
return 0;
}
然后我们在通过htons的方法转化大小端,就是所谓的系统高地位。
htons的源代码其实就是高字节位和低字节位相互转化的结果。所以,所有的htons,ntohs,htonl,ltonh,自定义的htonf, hton64i等都是相同的转法。
htons的讲解:http://blog.csdn.net/caomiao2006/article/details/5772186
#define htons(x) ((unsigned short int)((((unsigned short int)(x) & 0x00ff)<<8)|(((unsigned short int)(x) & 0xff00)>>8)))
其实这个方法就是相当于
#define Mask 0x00FF
unsigned short shift_fun3(unsigned short data)
{
unsigned short tmpb;
unsigned short tmpc;
tmpb=(data>>8)&Mask;
tmpc=(data<<8)&(~Mask);
data=tmpb|tmpc;
return data;
}
ps:这里引伸一下char的翻转,http://blog.csdn.net/syzcch/article/details/8149706