街机模拟游戏逆向工程(HACKROM)教程:[1]数据的存储与读取

news/2024/5/18 15:58:54 标签: 经验分享, 汇编, 游戏程序

简介

在计算机中,数据存储的介质一直在变化,从最早的穿孔纸带,到现在的固态硬盘。但存储的原理是一直没有变化的,在计算机中,我们所存储的数据,一直都是以二进制的形式被存储存在不同的介质中。

计算机用位 (bits) 来存储数据,每一位可以是两种状态之一:0或1,这就是二进制数字。而这种形式十分不方便记忆,所以,为了方便记忆,每个二进制数字,都可以转换为十六进制数字或十进制数字。

二进制十六进制十进制
0001$011
0010$022
0011$033
0100$044
0101$055
0110$066
0111$077
1000$088
1001$099
1010$0A10
1011$0B11
1100$0C12
1101$0D13
1110$0E14
1111$0F15

数据长度

在计算机中,最小的长度为位(bits),也是计算机中用来存储的基本单位。

当我们把8个位(bits),放到一起,那我们就得到了一个单字节(byte)的长度。

把两个单字节长度放到一起,就可以得到一个字 (word)的长度,或者叫双字节。

我们把两个字(word)放到一起,就可以得到一个长字 (long-word),或者叫四字节。

在街机游戏的逆向研究中,我们通常使用一个名为M68K的汇编语言,在这个汇编语言中,我们常用的数据长度就是这三种,分别用B,W,L来表示这三种数据的长度。而位的形式,在这个汇编中,也常常会使用。

长度二进制十六进制
字节0010 11002C
0010 1100 1111 01012C F5
长字0010 1100 1111 0101 1001 1101 0111 01102C F5 9D 76

二进制存储原理

我们以最早的穿孔纸带为例,来说明数据是如何存储的:

位(bits)76543210
10进制16进制值
1$01
2$02
3$03
4$04
5$05
6$06
7$07
8$08
9$09
10$0A
11$0B
12$0C
13$0D
14$0E
15$0F
16$10
32$20
128$80
255$FF

 我们把纸带的每一行看成是一个字节的长度,在纸带中,用1来表示该位置已穿孔,代表该位为1。用0来表示该位置未穿孔,代表该位为0。这样,我们就把这些数据保存在了一个纸带上面。

而对于现代的比如硬盘,光盘,它们的存储原理是一样的,只是存储的介质发生了变化,硬盘是用磁性物质的S和N极代表示该位置为0和1,光盘是用一个个凹凸来表示该位置的0和1。

当然,因为二进制数值难于阅读和记忆,我们用各种工具软件,从中读出来的数据是已经被转换为了16进制数值。

助记符

因为我们从计算机中所读取到的数据都是二进制,我们基本上很难去阅读和记忆,所以,这时我们需要一个翻译器,把他们翻译成人类方便理解的方式。比如在m68K汇编中,会把读取到的比如:

0011 1101 0111 1100 0000 0000 0000 0101 0000 0000 1111 1100
3D             7C            00               05              00              FC

 如果只查看二进制或十六进制数值,我们很难理解,这段数据有什么作用。所以,M68K把他翻译为一段方便阅读和记忆的助记符:

move.w  #5,$FC(a6)

 我们把这段助记符分成四个部份:

1、命令:                - move ,代表了这句代码在程序中的作用

2、操作长度:         - 指定该指令想要操作的数值长度,以B(字节),W(字),L(长字)表示

3、源操作数:        - 表示了数据的从哪里读取

4、目的操作数:    - 表示了数据在运算后会哪里会被修改或者操作


http://www.niftyadmin.cn/n/5324854.html

相关文章

element plus自定义组件表单校验

方式一: import { formContextKey, formItemContextKey } from "element-plus";// 获取 el-form 组件上下文 const formContext inject(formContextKey, void 0); // 获取 el-form-item 组件上下文 const formItemContext inject(formItemContextKey, …

Flink之Task重启策略

Task重启策略 1 策略API noRestart 无参数,task失败后不重启,整个job同时失败,默认策略. 代码示例 RestartStrategies.noRestart();fixedDelayRestart 参数注释restartAttempts最大重启次数delayBetweenAttempts重启时间间隔代码示例 // 最多重启5次,每次任务失败后间隔1s重启…

openFeign 多模块调用失败问题

第一次做一个完整的SpringCloud微服务项目,踩了好多好多坑,都记录下来! openFeign 多模块调用失败 排错第一阶段 创建一个openfeign服务,并把它注册到nacos上去 然后A模块通过Feign调用B模块 但是我在A模块实现AdminArticleServiceFeignClient这个接口,报错: 后面我查找这个问…

输电线路的“千里眼“?可视化图像在线监测装置技术解析!|深圳鼎信

由于高压输电线路通常会横跨郊区、林区、公路、铁路等复杂地区或重要设施,存在不少线路隐患,可能会威胁线路安全和人身安全,提前发现有利于及时消除,避免造成意外事故。因此,作为输电线路的“千里眼”,可视…

好物周刊#36:程序员简历

村雨遥的好物周刊,记录每周看到的有价值的信息,主要针对计算机领域,每周五发布。 一、项目 1. SmartDNS 一个运行在本地的 DNS 服务器,它接受来自本地客户端的 DNS 查询请求,然后从多个上游 DNS 服务器获取 DNS 查询…

What is `@RequestBody ` does?

RequestBody 是SpringMVC框架中的注解,通常与POST、PUT等方法配合使用。当客户端发送包含JSON或XML格式数据的请求时,可以通过该注解将请求体内容绑定到Controller方法参数上 作用 自动反序列化: SpringMVC会根据RequestBody注解的参数类型&…

后端使用response.reset()导致出现跨域问题

前言 今天联调文件下载的接口,由于自己用postman测试一直都没问题,但是在和前端联调的时候前端就会出现如下跨域的报错,但是项目是做了统一的跨域处理的,代码类似于下面: ApiOperation("下载附件")PostMap…

pytorch 通用训练代码讲解(very good)

文章目录 1. 模型训练参数设置2. 保证模型可复现性3. 设置device4 初始化模型权重及加载预训练权重4.1 初始化模型权重4.2 加载预训练权重4.3 在线下载预训练权重5 k-means 聚类anchors6 多卡同步bn及并行运行7 权重指数平滑ModelEMA7.1 EMA的原理及作用7.2 EMA的实现7.2 EMA的…