假定给出一个数组a[4]={0x6162,0x6364,0x6566,0x6768}
我们直接将其以字符串形式输出:
#include<stdio.h>int main(){ short a[4]={0x6162,0x6364,0x6566,0x6768}; printf("a:%s\n",a);}可以得到这样的结果:[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pp3ZCDYS-1618060462336)(/home/hadoop/图片/2021-04-10 20-51-07 的屏幕截图.png)]
理论上来讲我们得到的结果应该是abcdefgh,但是却出现了相反的结果这是为什么呢?
这是因为我们的CPU使用的是小端模式,即数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中。
所以当我们直接按字符串打印0x6162时结果会输出ba而不是ab。
那我们如何能够不改变小端模式而输出为序呢?
话不多说直接上代码:
#include<stdio.h>#include<string.h>int swap(char* a, char* b){ char t; { t = *a; *a = *b; *b = t; }}int main(){ short a[4]={0x6162,0x6364,0x6566,0x6768}; char * p,* s,* r; r=(char*)&a; printf("打印:%s\n",r); p=(char*)&a; s=p+1; int i=0; while(i<8) { swap(p+i,s+i); i=i+2; } printf("排序:%s\n",r);}结果:
当然这种办法是非常直接的,我们是直接使用用指针类型强制转换,取到数组中的地址,再使用指针交换的。
下面我们使用自定义函数Memcpy进行转换。
#include <stdio.h>#include <string.h>#include <assert.h> void *Memcpy(void *dest,void *src, unsigned int count){assert((dest!=NULL)&&(src!=NULL));int i=0,k=0;if(dest==src)return src;unsigned short* d=(unsigned short*)dest;char* s=(char*)src;while(count--> 0){d[i]=(s[k]<<8)|s[k+1];i+=1;k+=2;}return dest;} void main(){ int i; short value[24]={0}; short a[4]={0x6162, 0x6364, 0x6566, 0x6768};printf("打印:%s\n",a); Memcpy(value,a,4); printf("排序:%s\n",value);}结果: