c语言中的大端模式和小端模式

在学习共用体(联合体 union)的时候,碰到了非常经典的大小端模式问题,以下是个人的见解:

大端模式与小端模式

所有运算的操作数,必须在CPU的內部寄存器才能参与运算对于CPU来说,寄存器才是它真正的储存空间,但是CPU的寄存器的个数以及容量是非常有限的,所以在设计CPU时,必须要有一个它的存储器(Memory),把CPU寄存器中的数据 储存到 储存器memory中,同时也需要把存储器中的数据,加载到寄存器中来。
CPU寄存器 <>存储器==之间的数据交换。

寄存器:是按bits位储存
存储器:是按字节来连续编制

	高字节       低字节
R : (4) (3) (2) (1)


M :
	___ ___ ___ ___
低地址         高地址


小端模式 :  小存小

	存储中的低地址  存储 寄存器中  低字节
(1) (2) (3) (4)
___ ___ ___ ___
低地址       高地址
     

大端模式 :  小存大

	存储器中的低地址 存储 寄存器中的 高字节       
(4) (3) (2) (1)     
___ ___ ___ ___
低地址       高地址
//以下是判断大小端的两种方法:
#include<stdio.h>//指针方法
int main()
{
    int a=260;
    int* p=&a;
    printf("%d\n",*((char*)p));//这里输出为4
    printf("%d\n",*(((char*)p+1));//这里输出为1
    return 0;
}
#include<stdio.h>//联合体方法

union test//联合体公用一块内存,并且是最大的成员变量的内存
{
    int a;
    char b;
};

int main()
{
    union test t;
    t.a=1;
    printf("%d\n",t.b);//如果为1,则是小端,如果为0,则是大端
    if(t.b)
    {
        printf("小端模式!\n");
    }
    else
    {
        printf("大端模式!\n");
    }
    return 0;
}
posted @   风恬月淡时  阅读(106)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示