一个可以检测本机的字节顺序,并对任意数据进行字节顺序的反转操作的代码。

复制代码
#include <stdio.h>      // 标准输入输出库,用于printf等函数
#include <stdint.h>     // 标准整数类型库,提供uint8_t、uint16_t等类型
#include <string.h>     // 字符串操作库(虽然当前代码未直接使用,但常用于内存操作)

// 检测本机是大端还是小端格式
int is_little_endian() {
    uint16_t num = 0x0001;          // 创建一个16位整数,值为0x0001
    return *(uint8_t*)&num == 0x01; // 检查第一个字节是否为0x01(小端特征)
}

// 字节顺序转换函数
void change_byte_seq(void *p, size_t size, int flag) {
    if (size <= 1) return; // 单字节无需转换(字节序只影响多字节数据)
    
    uint8_t *bytes = (uint8_t*)p; // 将void指针转换为字节指针便于操作
    size_t i, j;                 // 循环索引变量
    
    // 反转字节顺序(对称交换)
    for (i = 0; i < size / 2; i++) {
        j = size - 1 - i;        // 计算对称位置索引
        uint8_t temp = bytes[i]; // 临时存储当前字节
        bytes[i] = bytes[j];     // 交换字节位置
        bytes[j] = temp;         // 完成交换
    }
}

// 测试函数
void test_conversion() {
    uint32_t num = 0x12345678;           // 定义一个测试用的32位整数
    printf("原始值: 0x%08x\n", num);     // 打印原始值
    
    // 转换为相反字节序
    change_byte_seq(&num, sizeof(num), 1); // 调用转换函数
    printf("转换后: 0x%08x\n", num);      // 打印转换结果(应显示0x78563412)
    
    // 转换回来
    change_byte_seq(&num, sizeof(num), 1); // 再次转换恢复原状
    printf("恢复后: 0x%08x\n", num);      // 打印恢复结果(应显示原始值)
}

int main() {
    // 检测本机字节序
    if (is_little_endian()) {
        printf("本机是小端格式 (Little Endian)\n");  // 最低有效字节在前
    } else {
        printf("本机是大端格式 (Big Endian)\n");    // 最高有效字节在前
    }
    
    // 测试字节序转换
    test_conversion();  // 执行测试案例
    
    return 0;          // 程序正常退出
}

关键代码段说明:

  1. is_little_endian()

    • uint16_t num = 0x0001:16位整数的内存布局在小端系统是01 00,大端是00 01

    • *(uint8_t*)&num:通过类型转换检查第一个字节的内容

  2. change_byte_seq()

    • 通过对称交换实现字节反转(例如0x123456780x78563412

    • flag参数当前未使用,但可扩展为方向控制(如0=大转小,1=小转大)

  3. test_conversion()

    • 演示转换的对称性:两次转换会恢复原始值

    • 典型输出:

      text

      复制代码
      原始值: 0x12345678  
      转换后: 0x78563412  
      恢复后: 0x12345678
  4. 内存操作

    • (uint8_t*)p:将任意类型指针转为字节指针,实现通用内存操作

    • size / 2:只需遍历前半部分即可完成交换(避免重复操作)

相关推荐
kyle~5 小时前
排序---插入排序(Insertion Sort)
c语言·数据结构·c++·算法·排序算法
Boop_wu6 小时前
[数据结构] 队列 (Queue)
java·jvm·算法
hn小菜鸡6 小时前
LeetCode 3643.垂直翻转子矩阵
算法·leetcode·矩阵
ElendaLee7 小时前
第八章 矩阵按键实验
嵌入式硬件·51单片机
三佛科技-134163842127 小时前
卷发棒/卷发梳MCU方案分析
单片机·嵌入式硬件
ゞ 正在缓冲99%…7 小时前
leetcode101.对称二叉树
算法
YuTaoShao7 小时前
【LeetCode 每日一题】3000. 对角线最长的矩形的面积
算法·leetcode·职场和发展
2zcode7 小时前
基于Matlab可见光通信系统中OOK调制的误码率性能建模与分析
算法·matlab·php
白掰虾7 小时前
STM32N6&AI资料汇总
人工智能·stm32·嵌入式硬件·stm32n6·stm32ai
纵有疾風起8 小时前
数据结构中的排序秘籍:从基础到进阶的全面解析
c语言·数据结构·算法·排序算法