【数据结构】汇编语言和机器语言的‘数据结构‘

前言

汇编语言没有像高级语言(如 C#、Java 等)那样直接提供数据结构(如数组、链表、树、栈等),但是可以通过对内存地址和寄存器的操作来实现这些数据结构。汇编语言的核心是直接操控计算机的内存,因此所有数据结构的实现都需要手动管理内存和指针。

下面介绍几种在汇编语言中实现基本数据结构的方式:


1. 数组(Array)

在汇编中,数组通常是通过一组连续的内存单元实现的。可以使用寄存器来存储数组的起始地址,然后通过索引偏移访问数组中的元素。

示例(x86 汇编,使用数组访问):

section .data
array db 10, 20, 30, 40, 50    ; 定义一个字节数组,包含5个元素section .text
global _start
_start:mov esi, array             ; 将数组起始地址存入 ESI 寄存器mov al, [esi+2]            ; 访问数组的第三个元素(值为30); 此时 al = 30

在这个例子中,array 是一个连续的内存区域,存储了 5 个字节数据。ESI 寄存器用来指向数组的起始地址,[esi+2] 表示访问偏移量为 2 的位置,即第三个元素。


2. 栈(Stack)

在汇编中,栈是一个非常常见的数据结构。栈通常通过 PUSHPOP 指令来实现。栈是基于后进先出(LIFO)原则的,即最后压入的数据最先弹出。

示例(x86 汇编,使用栈):

section .text
global _start
_start:mov eax, 10               ; 将值 10 放入 EAX 寄存器push eax                  ; 将 EAX 的值压入栈中mov eax, 20               ; 将值 20 放入 EAX 寄存器push eax                  ; 将 EAX 的值压入栈中pop ebx                   ; 从栈中弹出数据到 EBX 寄存器(值为 20)pop ecx                   ; 从栈中弹出数据到 ECX 寄存器(值为 10); 此时 ebx = 20, ecx = 10

栈的操作基于 ESP(栈指针寄存器),PUSH 指令将数据压入栈中并更新 ESP,而 POP 指令则从栈顶弹出数据并更新 ESP


3. 链表(Linked List)

链表在汇编中可以通过指针(内存地址)和数据节点实现。每个节点通常包含一个数据域和一个指向下一个节点的指针域。

示例(链表节点定义):

在汇编中,链表的每个节点可以由两个连续的内存区域来表示,一个存储数据,另一个存储下一个节点的地址。

section .data
node1_data dd 10                ; 节点1的数据
node1_next dd node2             ; 节点1的下一个节点地址node2_data dd 20                ; 节点2的数据
node2_next dd 0                 ; 节点2的下一个节点地址(0表示链表结束)

在这个例子中,node1node2 代表链表的两个节点。node1 包含数据 10,并指向下一个节点 node2node2 的数据为 20,且 node2_next0,表示链表的结尾。

访问链表节点:

可以通过寄存器指向链表节点的地址,并通过偏移量访问数据和下一个节点地址。


4. 队列(Queue)

队列在汇编中可以使用内存数组和两个指针(头指针和尾指针)实现。队列是一种先进先出(FIFO)的数据结构。

示例(队列的实现):

section .data
queue db 5 dup(0)           ; 定义一个大小为5的队列(字节数组)
head dw 0                    ; 队列头指针,初始化为0
tail dw 0                    ; 队列尾指针,初始化为0

在这个队列中,headtail 分别指向队列的头和尾。插入数据时,增加 tail 指针;取出数据时,增加 head 指针。当指针达到数组末尾时,可能需要进行回绕(循环队列)。


小结

汇编语言的数据结构实现依赖于内存管理寄存器操作,例如:

  • 数组:通过内存的连续地址和偏移实现。
  • :利用 CPU 的 ESP 栈指针及 PUSH/POP 指令操作。
  • 链表:使用内存中的节点地址和指针域来建立节点的链接。
  • 队列:通过数组和头尾指针模拟,依靠手动管理指针完成入队、出队操作。

这些数据结构在汇编中都要手动管理指针和内存,灵活性大但难度较高。

机器语言的’数据结构’

在机器语言中,数据结构的存储方式直接依赖于内存地址和 CPU 寄存器。机器语言是最低级别的编程语言,因此它没有内置的数据结构,只能通过直接的内存操作来模拟数据结构的行为。下面是一些机器语言中常见的数据存储和结构组织方式:


1. 基本数据(如整数、字符)

基本数据类型(如整数、字符)通常直接存储在内存地址中。每种数据类型都有固定的位宽,比如:

  • 字符char):通常用 1 个字节(8 位)表示。
  • 整数int):可以用 1、2、4、或 8 字节表示,具体取决于系统架构。

示例
假设一个内存单元存储了一个整数 5,在内存中存储方式如下:

地址
0x100005

这里,内存地址 0x1000 存储了整数 5。在机器语言中,程序可以直接访问地址 0x1000 来获取该值。


2. 数组

数组在机器语言中表示为一组连续的内存单元。数组的每个元素占用相同的内存空间,因此可以通过起始地址和偏移来访问每个元素。

示例:一个包含 4 个整数的数组,分别为 10, 20, 30, 40

地址
0x20000A
0x200414
0x20081E
0x200C28

在这个例子中:

  • 数组的起始地址是 0x2000
  • 每个整数占用 4 个字节。
  • 访问第 i 个元素的地址为 起始地址 + i * 元素大小

3. 栈(Stack)

栈是基于内存的“后进先出”(LIFO)结构,通常通过栈指针(例如 ESP 寄存器)管理。栈的数据结构存储在内存中,通常从高地址向低地址增长。每次向栈中添加数据(PUSH),栈指针都会减少;而每次从栈中移除数据(POP),栈指针都会增加。

示例
假设栈的初始地址为 0x3000,向栈中压入两个整数 1020,栈的结构如下:

地址
0x2FFC10
0x2FF820
0x3000ESP (栈顶指针)

在机器语言中,通过直接操作栈指针来控制数据的入栈和出栈过程。


4. 链表(Linked List)

链表在机器语言中是通过指针来实现的。每个节点包含两部分:数据区域和指针区域。指针区域存储下一个节点的地址。

示例:假设链表有两个节点,分别存储 50100,内存结构如下:

地址说明
0x400032第一个节点的数据(50)
0x40040x4008指向下一个节点的地址
0x400864第二个节点的数据(100)
0x400C0终止指针(0 表示结束)

在机器语言中,通过读取当前节点的地址,然后访问“指向下一个节点的地址”字段,即可遍历链表。


5. 队列(Queue)

队列在机器语言中可以用循环数组来实现,并使用两个指针来管理:一个指向队列头(front),一个指向队列尾(rear)。队列遵循先进先出(FIFO)原则。

示例:假设队列有 4 个字节的空间,用于存储 2 个数据 6070,内存结构如下:

地址说明
0x50003C队列头(60)
0x500446队列尾(70)

在机器语言中,通过移动队列头和尾指针,控制数据的入队和出队。


小结

机器语言中的数据结构是通过直接操控内存地址和寄存器来实现的。没有高级数据结构,只能使用以下方式模拟:

  • 基本数据:直接存储在单个内存单元或寄存器中。
  • 数组:通过连续的内存单元实现,使用偏移量访问。
  • :使用栈指针和 PUSH/POP 操作从高地址到低地址管理数据。
  • 链表:每个节点包含数据和指向下一个节点的指针。
  • 队列:用循环数组实现,通过头尾指针管理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/9876.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

稳压二极管详解

目录 1. 工作原理 2. 稳压二极管的伏安特性曲线 3. 正向特性: 4. 反向特性 5. 稳定电压(Vz) 6. 动态电阻(rz) 7.最大耗散功率(PzM) 8. 最大稳定工作电流(IzMAX)和…

Springboot 一个西餐主题网站-计算机设计毕业源码73020

目录 摘要 1 绪论 1.1 选题背景与意义 1.2国内外研究现状 1.3论文结构与章节安排 2系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1 数据流程 2.2.2 业务流程 2.3 系统功能分析 2.3.1 功能性分析 2.3.2 非功能性分析 2.4 系统用例分析 2.5本章小结 3 系统总体设…

JS渗透(安全)

JS逆向 基本了解 作用域: 相关数据值 调用堆栈: 由下到上就是代码的执行顺序 常见分析调试流程: 1、代码全局搜索 2、文件流程断点 3、代码标签断点 4、XHR提交断点 某通js逆向结合burp插件jsEncrypter 申通快递会员中心-登录 查看登录包…

世界技能竞赛大数据应用开发环境1:1还原

关注我,私信我获得集群环境 集群情况 模块A搭建环境,在容器中搭建大数据平台 Hadoop HA环境 Pc机,安装安装比赛需要软件 模块B中使用idea快速开发完成数据处理 模块E包含了接口数据,使用vs code快速搭建vue数据可视化

【c++丨STL】vector模拟实现

🌟🌟作者主页:ephemerals__ 🌟🌟所属专栏:C、STL 目录 前言 一、vector底层刨析 二、模拟实现 1. 属性、迭代器以及函数声明 2. 功能实现 交换两个容器的内容 构造函数 拷贝构造 赋值重载 析构…

指针的运用

接下来我将会用的话,讲解我对指针运用仅有的印象 1.解引用 int a23; int*p&a; *p666; 而*p666;,便是解引用操作,跟简单地说*p便是解引用,它的意思是,对p中所储存的地址所在位置的内容进行操作&#xf…

三周精通FastAPI:38 针对不同的编程语言来生成客户端

官方文档:https://fastapi.tiangolo.com/zh/advanced/generate-clients/ 生成客户端 因为 FastAPI 是基于OpenAPI规范的,自然您可以使用许多相匹配的工具,包括自动生成API文档 (由 Swagger UI 提供)。 一个不太明显而又特别的优势是&#…

广告联盟有哪些

随着互联网的发展,越来越多的人开始投身于网站建设和运营。对于站长来说,如何在提供优质内容的同时获取收益是一个重要的问题。广告联盟作为一种常见的盈利模式,受到了广大站长的青睐。本文将介绍5个适合国内站长的广告联盟平台,帮…

兵马未动,粮草先行-InnoDB统计数据是如何收集的

我们前面介绍查询成本的时候经常用到一些统计数据,比如通过SHOW TABLE STATUS可以看到关于表的统计数据,通过SHOW INDEX可以看到关于索引的统计数据,那么这些统计数据是怎么来的呢?它们是以什么方式收集的呢?本章将聚焦…

【Promise】JS 异步之宏队列与微队列

文章目录 1 原理图2 说明3 相关面试题3.1 面试题13.2 面试题23.3 面试题33.4 面试题4 1 原理图 2 说明 JS 中用来存储待执行回调函数的队列包含 2 个不同特定的队列:宏队列和微队列。宏队列:用来保存待执行的宏任务(回调),比如:定…

基础概念理解

一,数据结构分类 连续结构,跳转结构。 二,对变量的理解 在 C 语言中,变量是用于存储数据的抽象符号。变量本质上是一块内存区域的标识符(即它代表内存中的某一块区域),用来存储数据&#xff…

C 学习(4)

return 0; 前提:C 语言规定,main()是程序的入口函数,即所有的程序一定要包含一个main()函数。程序总是从这个函数开始执行,如果没有该函数,程序就无法启动。其他函数都是通过它引入程序的。 main()的写法&#xff0c…

欺诈文本分类检测(十八):基于llama.cpp+CPU推理

1. 前言 前文我们用Lora训练出自己的个性化模型后,首先面临的问题是:如何让模型在普通机器上跑起来?毕竟模型微调时都是在几十G的专用GPU上训练的,如果换到只有CPU的普通电脑上,可能会面临几秒蹦一个词的尴尬问题。 …

工程数学线性代数(同济第七版)附册课后习题答案PDF

《线性代数附册 学习辅导与习题全解》是与同济大学数学科学学院编《工程数学 线性代数》第七版教材配套的教学辅导书,由同济大学作者团队根据教材内容和要求编写而成。本书在《工程数学 线性代数》第六版附册(即辅导书)的基础上修改而成。全书…

传输层协议、ACL

第六章 传输层协议、ACL 文章目录 第六章 传输层协议、ACL1.TCP和UDP协议1.1 TCP协议1.2 TCP报文段1.3 TCP连接 2.UDP协议3.ACL概述ACL原理及种类ACL组成规则编号通配符(反掩码) 4.ACL应用ACL匹配规则ACL匹配规则 1.TCP和UDP协议 TCP/IP协议族的传输层协…

(蓝桥杯C/C++)——搜索

一、回溯法 1.回溯法简介 回溯法一般使用 ** DFS(深度优先搜索) ** 实现,DFS是一种遍历或搜索图、树或图像等数据结构的算法,当然这个图、树未必要存储下来(隐式处理就是回溯法),常见的是通过某种关系构造出的搜索树,搜索树一般…

Turtlebot3 buger 硬件与操作平台详细介绍

引言 TurtleBot3 有三个版本,分别是紧凑型的 Burger、功能更强的 Waffle和性能提升的 Waffle Pi,分别适用于不同的应用需求。使用 Raspberry Pi 作为主控单板计算机(SBC),而 Waffle Pi 可以使用更强大的 NVIDIA Jetson…

Ubuntu实现双击图标运行自己的应用软件

我们知道在Ubuntu上编写程序,最后编译得到的是一个可执行文件,大致如下 然后要运行的时候在终端里输入./hello即可 但是这样的话感觉很丑很不方便,下边描述一种可以类似Windows上那种双击运行的实现方式。 我们知道Ubuntu是有一些自带的程序…

Chromium Mojo(IPC)进程通信演示 c++(4)

122版本自带的mojom通信例子仅供学习参考: codelabs\mojo_examples\01-multi-process 其余定义参考文章: Chromium Mojo(IPC)进程通信演示 c(2)-CSDN博客 01-mojo-browser.exe 与 01mojo-renderer.exe进程通信完整例子。 一、…

基于Prometheus的client_golang库实现应用的自定义可观测监控

文章目录 1. 安装client_golang库2. 编写可观测监控代码3. 运行效果4. jar、graalvm、golang编译运行版本对比 前文使用javagraalvm实现原生应用可观测监控: prometheus client_java实现进程的CPU、内存、IO、流量的可观测,但是部分java依赖包使用了复杂…