大小端问题2

来源:互联网 发布:sql server oracle 编辑:程序博客网 时间:2024/05/16 08:58

之前有学习过系统的大小端问题。还在网上找了很多资料学习。这次又碰到了,而且还让我找了良久。

这次的问题是这样的。在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  0x00FFunsigned 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


0 0
原创粉丝点击