//2.59
#include <stdio.h>
using namespace std;
#define byte_pointer unsigned char *
//判断当前计算机是大端存储还是小端存储
int is_little_endian(){
int tempi=1;
return(*(byte_pointer)&tempi);
}
//输出指定数的各字节的16进制表示
bool show_bytes(byte_pointer data,int index){
for(int i=0;i<index;++i){
printf("%0x",data[i]);
}
printf("\n");
}
//交换指定数的第0个字节
int MakeupWord(int x,int y){
if(is_little_endian()){
((byte_pointer)&y)[0]=((byte_pointer)&x)[0];
}else{
((byte_pointer)&y)[sizeof(int)-1]=((byte_pointer)&x)[sizeof(int)-1];
}
return y;
}
int main()
{
int tempi=MakeupWord(0x89ABCDEF,0x76543210);
show_bytes((byte_pointer)&tempi,sizeof(int));//输出 ef325476 (因为intel处理器基本上是小端存储,所以该数实为0x765432ef)
return 0;
}
*其实单纯的只是交换第0个字节完全可以这样写:
(x&0xFF)|(y&~0xFF)//注意:0xFF-->0000...1111;~0xFF-->1111..0000这里之所以弄这么复杂,是为了使其可以稍加改动就可以交换任意字节
本文介绍了一种用于交换整数变量中特定字节的方法,并通过示例代码展示了如何在小端和大端系统中实现这一操作。此外,还提供了一个简单的函数来判断当前系统采用的是哪种端序。
1163

被折叠的 条评论
为什么被折叠?



