c 判断大端字节序小端字节序

大端字节序和小端字节序的基本概念
大端字节序:高位字节在前,低位字节在后。
小端字节序:低位字节在前,高位字节在后。
假设有一个十六进制的数0x12345678(高位为0x12,低位为0x78),地址范围为0x100·0x103的字节存储顺序依赖于机器的类型:
在这里插入图片描述

这里使用联合和指针两种方法

/*********************************************************************************
 *      Copyright:  (C) 2021 jiaoer237
 *                  All rights reserved.
 *
 *       Filename:  unio.c
 *    Description:  This file 
 *                 
 *        Version:  1.0.0(11/15/2021)
 *         Author:  yanp <2405204881@qq.com>
 *      ChangeLog:  1, Release initial version on "11/15/2021 09:01:13 AM"
 *                 
 ********************************************************************************/
#include <stdio.h>

void is_lsb(void);
void is_lsb1(void);

int main()
{
    is_lsb();/*使用联合的属性来判断是否是小端字节序*/
    is_lsb1();/*使用指针判断是否是小端字节序*/
    return 0;
}

/*使用联合来判断大段字节序或者小端字节序*/
void is_lsb(void)
{
    union u_data
    {
        unsigned char a;
        unsigned int b;
    }data;

    data.b=0x12345678;
    printf("data size is %ld\n",sizeof(data));
    printf("b=%x\n",data.b);
    printf("a=%x\n",data.a);
    if(data.a==0x78)
    {
        printf("the os is LSB\n");
    }
    else if(data.a==0x12)
    {
        printf("the os is MSB\n");
    }
    else
    {
        printf("wrong\n");
    }
}

/使用指针来判断大端字节序还是小端字节序/
void is_lsb1(void)
{
    unsigned int a=0x12345678;
    unsigned char *p;
    p=(unsigned char *)&a; /*强制类型转换成unsigned char *类型*/
    printf("*p=%x\n",*p);
    if(*p==0x78)
    {
        printf("os is lsb\n");
    }
    else if(*p==0x12)
    {
        printf("os is msb\n");
    }
    else
    {
        printf("wrong\n");
    }
}

输出结果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值