当前位置: 首页 > news >正文

你是真的“C”——【经典面试知识点】数据在内存中的大小端存储方式

你是真的“C”——【经典面试知识点】数据在内存中的大小端存储方式😎

  • 前言🙌
  • 大小端介绍🙌
    • 什么大端小端呢?:
      • 大小端存储的标准定义:
      • 大端和小端存在的意义
  • 经典的面试题目🙌
  • 总结撒花💞

  追梦之旅,你我同行

   
😎博客昵称:博客小梦
😊最喜欢的座右铭:全神贯注的上吧!!!
😊作者简介:一名热爱C/C++,算法等技术、喜爱运动、热爱K歌、敢于追梦的小博主!

😘博主小留言:哈喽!😄各位CSDN的uu们,我是你的博客好友小梦,希望我的文章可以给您带来一定的帮助,话不多说,文章推上!欢迎大家在评论区唠嗑指正,觉得好的话别忘了一键三连哦!😘
在这里插入图片描述

前言🙌

    哈喽各位友友们😊,我今天又学到了很多有趣的知识现在迫不及待的想和大家分享一下!😘我仅已此文,和大家分享【经典面试知识点】数据在内存中的大小端存储方式~ 接下来都是精华内容,可不要错过哟!!!😍😍😍

大小端介绍🙌

什么大端小端呢?:

大小端存储的标准定义:

大端(存储)模式是指数据的低位字节的数据保存在内存的高地址中,而数据的高位字节的数据保存在内存的低地址中“;
小端(存储)模式是指数据的低位字节数据保存在内存的低地址中,而数据的高位字节数据保存在内存的高地址中

大端和小端存在的意义

为什么会有大小端模式之分呢?

  1. 这是因为在计算机系统中,是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8 bit。但是在C语言中除了8 bit的char之外,还有16 bit的short型,32 bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式
  2. 我们常用的 X86 结构是小端模式,而 KEIL C51 则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式

经典的面试题目🙌

题目:请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序。

  • 简述大端字节序和小端字节序的概念:
    1 . 大端字节序:把一个数据的低位字节中的数据,存放到内存的高地址处;高位字节中的数据,存放到内存的低地址处。
    2 .小端字节序:把一个数据的低位字节中的数据,存放到内存的低地址处;高位字节中的数据,存放到内存的高地址处。

在这里插入图片描述
如上图所示,我们可以通过1,来判断其低字节的数据。如果为1,则是小端存储;为0,则为大段存储。

小程序设计代码:

#define _CRT_SECURE_NO_WARNINGS 1#include<stdio.h>
int check_sys()
{int a = 1;char* p = (char*)&a;if (*p == 1)return 1;//小端elsereturn 0;//大端
}int main()
{if (check_sys() == 1)printf("小端字节序存储方式\n");elseprintf("大端字节序存储方式\n");return 0;
}

该程序代码可不可以再进行一个优化呢?其实是可以的。下面是优化的程序代码:

#include<stdio.h>
int check_sys()
{int a = 1;return *((char*)&a);
}int main()
{if (check_sys() == 1)printf("小端字节序存储方式\n");elseprintf("大端字节序存储方式\n");return 0;
}

总结撒花💞

   本篇文章旨在分享【经典面试知识点】数据在内存中的大小端存储方式的相关知识点。希望大家通过阅读此文有所收获!😘如果我写的有什么不好之处,请在文章下方给出你宝贵的意见😊。如果觉得我写的好的话请点个赞赞和关注哦~😘😘😘

http://www.lryc.cn/news/7452.html

相关文章:

  • 从零开始的数模(二十六)单因素方差分析
  • C++变量类型
  • win10 安装 vs2015(社区版本)以及opencv-4.5.5
  • 867. 转置矩阵
  • Datawahle组队学习——妙趣横生大数据 Day1
  • 网友眼中越老越吃香的行业,果然是风向变了!
  • 为什么时间序列预测这么难?本文将给你答案
  • STC15系列单片机通过串口多字节数据读写EEPROM操作
  • 计算机网络-ip数据报
  • 从零开始学C
  • 【云原生】手把手带你从零开始搭建kubernetes最新版本实战
  • trivy os软件包扫描原理分析
  • 算法训练营 day48 动态规划 完全背包 零钱兑换 II 组合总和 Ⅳ
  • Java 基础(1)—泛型简单使用
  • 内存卡损坏了怎么恢复?
  • Mysql使用规范(纯技术和实战建议)
  • Netty源码解读-EventLoop(二)
  • OSI模型详解
  • Share Creators完成500万美元融资,以工具化手段帮助企业从数字资产管理中解放
  • 几个Base64编码工具,也有蹊跷
  • Python|每日一练|排序|递归|字符串|数组|动态规划|单选记录:以特殊格式处理连续增加的数字|正则表达式匹配|地下城游戏
  • Spring Cloud微服务网关Gateway组件
  • cluster nodes(集群节点)
  • 【Android学习】下载jar慢和gradle慢的情况
  • 下一个排列-力扣31-java
  • 前端面试题
  • jsp游戏门户网站系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
  • Git与IDEA强强联合(HTTPS协议连接)
  • leetcode 第二题:两数相加-C语言实现
  • 【人工智能】PTP网络时钟服务器在智能驾驶里的重要性