大小端问题2

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

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


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值