C语言面试篇1:判断数据大小端存储

一、前言

本节,我们将学习C语言库中数据存储方式,并通过编写代码确定当前系统的数据存储方式。

二、简介

1.大端模式

大端模式是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中。

2.小端模式

小端模式是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中。

3.为什么会有大小端之分?

为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为 8bit。但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于 8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。

4.图例说明

图中表示数据0x12345678的数据存储方式。

三、实例

1.指针方式

#include?<stdio.h>
int?is_big_endian(void)
{
????int?val?=?0x12345678;
????char?data?=?0;
????data?=?((char*)&val)[0];
????if?(0x12?==?data)
????{
????????return?1;
????}else?if(0x78?==?data)
????{
????????return?0;
????}
}
int?main(void)
{
????if?(1?==?is_big_endian())
????{
????????printf("system?is?large?endian!\r\n");
????}else?if?(0?==?is_big_endian())
????{
????????printf("system?is?small?endian!\r\n");
????}
????return?0;????
}

执行结果如下:

2.共用体方式

#include?<stdio.h>
union?udata
{
????int?a;
????char?b;
}data;
int?is_big_endian(void)
{
????data.a?=?0x12345678;
????if?(0x12?==?data.b)
????{
????????return?1;
????}else?if?(0x78?==?data.b)
????{
????????return?0;
????}
}
int?main(void)
{
????if?(1?==?is_big_endian())
????{
????????printf("system?is?large?endian!\r\n");
????}else?if?(0?==?is_big_endian())
????{
????????printf("system?is?small?endian!\r\n");
????}
????return?0;????
}

执行结果如下:

四、结语

如您在使用过程中有任何问题,请加QQ群进一步交流,也可以github提Issue。

QQ交流群:906015840 (备注:物联网项目交流)

github仓库地址:https://github.com/solitary-sand/c

一叶孤沙出品:一沙一世界,一叶一菩提

原文地址:https://blog.51cto.com/14616151/2459463

时间: 2024-10-12 09:09:09

C语言面试篇1:判断数据大小端存储的相关文章

【转】大小端存储模式精解

计算机系统中内存是以字节为单位进行编址的,每个地址单元都唯一的对应着1个字节(8 bit).这可以应对char类型数据的存储要求,因为char类型长度刚好是1个字节,但是有些类型的长度是超过1个字节的(字符串虽然是多字节的,但它本质是由一个个char类型组成的类似数组的结构而已),比如C/C++中,short类型一般是2个字节,int类型一般4个字节等.因此这里就存在着一个如何安排多个字节数据中各字节存放顺序的问题.正是因为不同的安排顺序导致了大端存储模式和小端存储模式的存在. 1. 概述 1.

C# Socket流数据大小端读写封装

网络数据是大端模式,而c#中的数据小端结构,那么在读写网络数据的时候需要进行转换.c#类库IPAddress已经封装了大小端的转换. 封装代码如下: [csharp] view plain copy using System.IO; using System.Net; using System; namespace Framework { public class NetStream { private MemoryStream stream; private BinaryReader read

堆栈方向以及大小端存储

在程序的设计中,都会涉及都堆栈的使用,其实堆栈是指堆和栈,它们是两个不同的概念,其中堆是通过用户来调用的内存空间,需要用户主动分配和释放,如果只分配而不即使释放,则可能出现内存泄漏的问题,其结果的难以估量的:栈是系统自动调用的内存空间,系统也会根据实际情况自动去释放该空间. 在平时的使用当中,我们需要注意堆栈(这里仅指栈)的增长方向,一般来说,当堆栈指针(栈顶)由高地址向低地址增长时,我们称为向下增长,:当堆栈指针(栈顶)由低地址向高地址增长时,我们称为向上增长. 在程序设计中我们还需要注意的就

大小端存储

字节的高位与低位举个例子,int a = 0x12345678 ; 那么左边12就是高位字节,右边的78就是低位字节,从左到右,由高到低,(注意,高低乃相对而言,比如56相对于78是高字节,相对于34是低字节). 大端模式,是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放: 小端模式,是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低

判断机器大小端模式的方法

首先我们要明白啥子叫大端模式.小端模式. 大端模式,是指数据的高位,保存在内存的低地址中,而数据的低位,保存在内存的高地址中: 小端模式,是指数据的高位,保存在内存的高地址中,而数据的低位,保存在内存的低地址中: 大端模式和我们的逻辑有点相反,而小端模式和我们的逻辑是一致的: 对于32位的系统,他一个字长是4个字节.那么对于数据0x12345678 你可以在linux的目录下建立一个文件,将数据0x12345678输入进去,保存文件. 利用命令 od -x  filename  查看 测试结果是

大小端的独特判定方法

看见这个判定方法很特别,收集了~ int i=1; char *p=(char *)&i; if(*p==1) printf("1"); else printf("2"); 大小端存储问题,如果小端方式中(i占至少两个字节的长度)则i所分配的内存最小地址那个字节中就存着1,其他字节是0.大端的话则1在i的最高地址字节处存放,char是一个字节,所以强制将char型量p指向i则p指向的一定是i的最低地址,那么就可以判断p中的值是不是1来确定是不是小端. 请写一

(转)大小端模式详解

int i=1; char *p=(char *)&i; if(*p==1) printf("1"); else printf("2"); 大小端存储问题,如果小端方式中(i占至少两个字节的长度)则i所分配的内存最小地址那个字节中就存着1,其他字节是0.大端的话则1在i的最高地址字节处存放,char是一个字节,所以强制将char型量p指向i则p指向的一定是i的最低地址,那么就可以判断p中的值是不是1来确定是不是小端. 请写一个C函数,若处理器是Big_end

大小端和联合体

不同的cpu存储方式也是不同,我们常见的x86就是小端模式,而有些arm则是大端模式. 大小端排序是针对字节之间的排序关系,而字节内部顺序是不变的. 小端:低字节排在内存的低地址,高字节排在内存的高地址 大端:高字节排在内存的低地址,低字节排在内存的高地址 例如:int a=0x12345678 小端模式存储: 内存 0x000000 0x000001 0x000002 0x000003 数据 0x12 0x34 0x56 0x78 大端模式存储: 内存 0x000000 0x000001 0x

ios开发——面试篇C语言精华

面试篇C语言精华 1.面向过程:分析解决问题所需要的步骤,然后用函数把这些步骤一步一步实 现. 面向对象:直接描述客观世界的对象及其相互关系.现实世界中任何实体都 可以看作是对象,对象之间通过消息相互作用,利用面向对象编程,我们只关心 借口,不关心怎样实现. 2.C++的三个特性:继承.封装和多态. 继承:一个对象直接使用另一个对象的属性和方法.继承可以使子类具有父 类的各种属性和方法,而不需要再次编写相同的代码. 封装:在程序上,隐藏对象的属性和实现细节,仅对外公开接口,控制属性 的读和修改的