结合Union谈大端模式,小端模式,网络字节

2024-05-11 13:18

本文主要是介绍结合Union谈大端模式,小端模式,网络字节,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CPU型号:Intel(R) Core(TM) i5-2450M 

系统:windows 10

IDE:Microsoft Visual C++ 6.0(下文中简称VC)

制图软件:Photoshop cs5

预备知识:

1. union的空间大小为以其成员变量中所占最大内存字节数进行内存对齐(VC默认为4字节对齐,,不足4字节补0),所有成员共享同一段内存地址,存放顺序为从低地址到高地址依次存放。


首先介绍下何为大端模式、小端模式以及网络字节:

数据的存储形式是以二进制进行存储的,存储器中的存储单元为一个字节。当数据为多个字节时,就涉及到顺序问题:高位是存在低地址还是高地址?图1详细说明了该问题。


图1


接下来我们用一段C++代码来测试Intel CPU是大端模式还是小端模式:

#include <stdio.h>
union
{char c[4];int i; 
}u;void main(void)
{int i=0;u.i = 0x44332211;printf("Memories:");for(i=0;i<4;i++)printf("%X",u.c[i]);printf("\nOut:%X\n",u.i);}

经过调试可看到u的地址中显示的数据,11对应地址0x00417C78,22对应地址为0x427c79,以此类推:


打印出结果为(16进制表示):


前面输入的数字为0x44332211,内存中低地址存的低位,因此可知本人的电脑为小端模式。

好了,现在有个新问题,前面是将数据存在内存,然后在读出,如果直接往内存中写数据,读出来会不会有点不一样?

#include <stdio.h>
union
{char c[4];int i;	   
}u;void main(void)
{int i=0;u.c[0] = 0x1;u.c[2] = 0x2;	//注意,此处u.c[1]并没有写入数据printf("Memories:");for(i=0;i<4;i++)printf("%X ",u.c[i]);printf("\nOut:%X\n",u.i);}

打印结果(16进制表示)


马虎的人可能会问,结果不是应该是201吗,2跟1分别占一个字节,中间补一个0。这就涉及到二进制了,通过调试可以看到:


一个数字表示4个比特位,而1跟2分别代表4个比特位,比一个字节8个比特位少了4个比特位,因此要补0,打印的结果应该这样看:


一个数字是表示4个比特位,不足位的要补0,不能以十进制的思维想当然!

这篇关于结合Union谈大端模式,小端模式,网络字节的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/979640

相关文章

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序

迭代器模式iterator

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/iterator 不暴露集合底层表现形式 (列表、 栈和树等) 的情况下遍历集合中所有的元素