• 电脑大小端自测


    首先说明,电脑大小端指的是一种存储模式。

    1.为什么有大小端:

          在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为 8bit。但是在C语言中除了8bit的char之外,还有16bit

    的short型,32bit的long型(要看具体的编译器),另外,对于位数大于 8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那

    么必然存在着一个如何将多个字节安排的问题,因此就导致了大端存储模式和小端存储模式。

    2.大小端定义:

    大端模式(Big-endian),是指数据的高字节,保存在内存的低地址中,而数据的低字节,保存在内存的高地址中

    小端模式(Little-endian),是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中

    3.直接来看一个图,详细说明大小端:

    例子:int i = 0x12345678 两种模式存入内存:


    很容易看出来,大小端的定义。

    4.下面就看看判断大小端的算法:

    写程序之前,需要先了解一件事:数据寻址时,用的是低位字节的地址。也就是从低位开始:

    #pragma once
    
    
    int CheckSystem()
    {
    	union check
    	{
    		int i;
    		char ch;
    	}c;
    
    	c.i = 1;
    	
    	return (c.ch == 1);
    }
    
    void Test()
    {
    	int check = CheckSystem();
    	if (check == 1)
    		cout << "当前系统为小端" << endl;
    	else
    		cout << "当前系统为大端" << endl;
    }
    
    
    ///////////////////////////////////////////////////////////////
    // 公用的四个字节地址 :0x1001 -> 0x1002 -> 0x1003 -> 0x1004
     //  小端来说  赋值 1 : 0x01      0x00      0x00      0x00
    //   大端来说  赋值 1 : 0x00      0x00      0x00      0x01 
    //也就是说存数据都是从低地址存放 一个char字节,
    //他和int开始的地址是一样的 读的话 还是从低字节向高字节完整的读取
    ////////////////////////////////////////////////////////////////
    甚是明白,联合体,成员共用内存,大小端存储模式不同,而char只和int公用一个字节,读取都是从低字节寻址,低字节的0和1就足以判断系统大小端模式了!

    赐教!

  • 相关阅读:
    springboot2的redis缓存管理器cacheManager配置,使存入json格式数据
    td内有图片和文字,如何都垂直居中?
    java使用itext导出PDF文本绝对定位
    plsqlDeveloper快速输入(自动替换)配置
    ExtJs4grid合并行
    MySQL存储引擎与体系结构
    Spring AOP
    在IoC容器中装配Bean
    java内存区域与内存溢出异常
    spring IoC(一)
  • 原文地址:https://www.cnblogs.com/melons/p/5791828.html
Copyright © 2020-2023  润新知