2.第二阶段x86游戏实战2-认识进制、理解数据宽度和位的概念

本文主要是介绍2.第二阶段x86游戏实战2-认识进制、理解数据宽度和位的概念,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动!

本次游戏没法给

内容参考于:微尘网络安全

工具下载:

链接:https://pan.baidu.com/s/1rEEJnt85npn7N38Ai0_F2Q?pwd=6tw3

提取码:6tw3

复制这段内容后打开百度网盘手机App,操作更方便哦

上一个内容:1.第二阶段x86游戏实战2-前言

进制、数据宽度、位是一个必要的前置知识,所以本次就把进制、数据宽度、位用傻瓜模式写清楚

首先是进制

在现实生活当中也会用到进制这个东西,现实生活中经常用到的0、1、2、3、4、5、6、7、8、9 它们就属于十进制,然后计算机它只认识0或1,这种0或1的被称为二进制,然后还有个十六进制为什么这里要提十六进制?因为作为逆向程序员看0或1会很难看懂,所以一些逆向工具(比如WinHex、OD)就会把0或1的二进制转成十六进制给我们逆向程序员看,转成十六进制之后会比看二进制容易一些,所以就用到了十六进制所以也就提到了十六进制,逆向过程中遇到的基本就是二进制、十进制、十六进制,然后二进制、十进制、十六进制、其它进制之间的互转公式暂时不需要知道,知道了用处也不大还浪费时间,互相转换这件事等对内存有一定了解之后会发现这都不是问题,所以为了快速掌握逆向不会再进一步去写,也没有必要进一步再写

然后十进制是0、1、2、3、4、5、6、7、8、9,这些数字

十六进制是0、1、2、3、4、5、6、7、8、9,a、b、c、d、e、f,这些数字,然后a对应10、b对应11、c对应12、d对应13、e对应14、f对应15

二进制是 1或1

然后现在就应该知道了进制的事情,也知道了十进制、十六进制、二进制的范围,接下来就是数据宽度

数据宽度(位)

介绍:

在现实生活当中没有宽度这个概念,包括在数学当中也没有宽度的概念,计算机受到硬件的影响,特别是古代(几十年前)硬盘、软盘等空间有限,所以就导致计算机当中的数据都存在宽度这个概念,超出宽度的部分会被丢掉

计算机当中汇编当中有4个宽度的概念 位、字节、字、双字,然后位的单位是bit、字节的单位是Byte、字的单位是WORD、双字的单位是DWORD,这里涉及到了英文顺嘴提下我们国人学计算机要不要学英语,答案是完全不需要,某些英语会频繁使用,使用的长了可能会不知道怎么读不知道什么意思但一定会知道这个英文写出来会有什么效果,也就是看到这个英语单词之后你会知道它有什么作用,知道这些就够了,所以完全不需要学习英语(实在想知道英语单词可以去百度翻译)

宽度:

位的宽度是1个0或1

字节的宽度是8个0或1

字的宽度是16个0或1

双字的宽度是32个0或1

image-20240904211507634

用什么宽度就读多少位超过的不会读,比如用字去读一个原本双字的数据这就会因为使用字去读而读不完整

现在需要知道的进制转换

首先如何观看二进制?如下图每一位二进制对应的数字,从右到左依次用前面的数字乘以2(2的n次方,2的16次方就说明有16位),为什么是从右到左这是因为内存大端序小端序的原因,大端序小端序现在涉及不到所以现在不是很重要,现在只需要记着内存存储数据一般默认(家用电脑)都是从右到左的方式存储的就好

然后二进制转十进制的方式是只要二进制数是1的就会拿出来进行相加,如下图右边第一个第二个是1结果就相当于把1和2拿出来进行相加,所以二进制11的十进制就是3

其它的例子如下图实际上就是64+4+2=70

然后上面是二进制转十进制的例子,它是把二进制值是1的位拿出来进行相加,二进制转十六进制也是把二进制值是1的位拿出来进行相加,它们区别是,如下图二进制转十六进制要拆开,每4个二进制组成一个数字,上面转十进制的时候是只要是1就进行相加,不会拆,而十六进制会根据十六进制数的位数拆成多组,每一组由4个二进制数组成,也就是每4个二进制数组成一位十六进制数

再比如一个三位数的十六进制数,二进制就要拆成3组(或者说3个)4位的二进制,如下图,可以发现十六进制不管是几位的都要拆成1位1位的然后再拼起来(每4个二进制一组左边的就放左边右边的就放右边),如下图8F6这是一个三位数的十六进制,这里就不能把8F6看成一个整体,要看成8、F、6这样的三个一位的十六进制数字,然后一位的数字由4个二进制数组成,如果不满足4个二进制在使用的时候一般为了好看会手动在左边补0让它变成4个二进制

如果把5C7D转成二进制,首先把5C7D拆分成 5、C、7、D,5的二进制组成应该是1+4,也就是0101,C对应也就是12,12它对应的二进制是8+4,也就是1100,7对应的二进制是4+2+1也就是0111,D对应的数字是13,13的二进制是8+4+1,也就是1101

组合起来 0110 1100 0111 1101

相信到这肯定把进制和进制转换看明白了,我觉得够傻瓜了这还看不懂来私信


img

这篇关于2.第二阶段x86游戏实战2-认识进制、理解数据宽度和位的概念的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

Java 队列Queue从原理到实战指南

《Java队列Queue从原理到实战指南》本文介绍了Java中队列(Queue)的底层实现、常见方法及其区别,通过LinkedList和ArrayDeque的实现,以及循环队列的概念,展示了如何高效... 目录一、队列的认识队列的底层与集合框架常见的队列方法插入元素方法对比(add和offer)移除元素方法

Spring Boot基于 JWT 优化 Spring Security 无状态登录实战指南

《SpringBoot基于JWT优化SpringSecurity无状态登录实战指南》本文介绍如何使用JWT优化SpringSecurity实现无状态登录,提高接口安全性,并通过实际操作步骤... 目录Spring Boot 实战:基于 JWT 优化 Spring Security 无状态登录一、先搞懂:为什

C++11中的包装器实战案例

《C++11中的包装器实战案例》本文给大家介绍C++11中的包装器实战案例,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录引言1.std::function1.1.什么是std::function1.2.核心用法1.2.1.包装普通函数1.2.

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点

Spring IOC核心原理详解与运用实战教程

《SpringIOC核心原理详解与运用实战教程》本文详细解析了SpringIOC容器的核心原理,包括BeanFactory体系、依赖注入机制、循环依赖解决和三级缓存机制,同时,介绍了SpringBo... 目录1. Spring IOC核心原理深度解析1.1 BeanFactory体系与内部结构1.1.1

MySQL中的DELETE删除数据及注意事项

《MySQL中的DELETE删除数据及注意事项》MySQL的DELETE语句是数据库操作中不可或缺的一部分,通过合理使用索引、批量删除、避免全表删除、使用TRUNCATE、使用ORDERBY和LIMI... 目录1. 基本语法单表删除2. 高级用法使用子查询删除删除多表3. 性能优化策略使用索引批量删除避免

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE