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

复制代码
#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:只需遍历前半部分即可完成交换(避免重复操作)

相关推荐
wuweijianlove2 小时前
算法性能的渐近与非渐近行为对比的技术4
算法
_dindong2 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志2 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
黎阳之光3 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
UTP协同自动化测试3 小时前
物联网模组测试难点 |APP指令下发+UART 响应+GPIO 电平变化,如何一次性验证?
功能测试·嵌入式硬件·物联网·模块测试
skywalker_113 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia3 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
wfbcg3 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展
_日拱一卒3 小时前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode
计算机安禾3 小时前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio