大小端问题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
- 大小端问题2
- 存储大小端问题
- 大小端存储问题
- 大小端问题
- cpu大小端问题
- 大小端问题
- 大小端问题
- 大小端问题
- 大小端存储问题
- 大小端问题
- 大小端问题
- 大小端问题
- 大小端问题
- 大小端判断问题
- 存储大小端问题
- 大小端问题
- 大小端问题
- 大小端问题
- Servlet--HttpServletRequest接口,HttpServletResponse接口
- 修正CGBitmapContextCreate iOS8上的错误
- 点击扫描仪老提示操作无法完成(0x00000015 )设备未就绪
- 设置notepad++默认以utf-8格式保存
- Yii中relations里配置和一些个人经验
- 大小端问题2
- Android自定义View的实现方法,带你一步步深入了解View(四)
- 群策CRM全网版,打通全网“一站式”盈利
- MVC 数据分析系统
- WIN7 IIS7.5web部署.NET项目遇到的问题
- J2EE是什么(二)
- JDK自带的动态代理Proxy类和InvocationHandler接口
- 冒泡算法 SAS & Python
- 微软100题(83)百度面试题_memmove实现