当前位置: 首页 > news >正文

汇编:数据定义数据填充

数组的定义

在32位汇编语言中,定义数组时,通常使用定义数据指令(如 DB, DW, DD,DQ )和标签来指定数组的名称和内容。DB定义字节数组(每个元素占1字节)、DW定义字数组(每个元素占2字节)、DD定义双字数组(每个元素占4字节)、DQ定义四字数组(每个元素占8字节),以下是常见的数组定义格式:

.data
byte_array db 13,23,14,25,30  ;定义一个包含5个字节(8位)的数组
word_array dw 1, 2, 3, 4, 5   ; 定义一个包含5个字(16位)的数组
qword_array dq 1234567890123456789, 9876543210987654321  ; 定义四字数组

如果此时我们要定义一个未进行初始化的数据,则格式为:

数组名 命令 元素个数 dup(?)

此时要定义一个有20个字节元素的数组barray,则可以这样定义:

barray db 20 dup(?)

这个时候如果要手动对数组进行修改或者初始化则需要使用stos系列的指令;STOS 指令在 x86 汇编语言中用于将数据从累加器寄存器(ALAXEAX)存储到由目的地址寄存器(EDI)指示的内存位置。具体来说,STOS 指令有三个变体:STOSBSTOSWSTOSD,分别用于存储字节、字和双字数据。

数组数据填充

STOS系列操作步骤
  1. 存储数据:将 ALAXEAX 的内容存储到由 EDI 指示的内存位置。

  2. 调整 EDI:根据方向标志(DF)调整 EDI

  • DF = 0(向前):EDI 递增(STOSB 递增1字节,STOSW 递增2字节,STOSD 递增4字节)默认

  • DF = 1(向后):EDI 递减(STOSB 递减1字节,STOSW 递减2字节,STOSD 递减4字节)

CLD:清除方向标志,使指针递增。
STD:设置方向标志,使指针递减。

此时我要对刚刚定义的barray数组/或者上面的byte_array等数组进行修改或者初始化,那么可以这样做(此处以barray为例子),该程序功能为将 barray 数组中的 20 个字节全部填充为 0xCC

.586
.model flat,stdcall
option casemap:none
​
.data
byte_arr db 13,23,14,25  ;定义一个字节数组 byte_arr,包含 4 个字节
barray db 20 dup(?)      ;定义一个未初始化的字节数组 barray,包含 20 个字节
​
.code
main procmov ecx,20mov al,0cchmov edi,offset barray   rep stosb  ;REP指令前缀用于重复执行紧随其后的字符串操作指令,直到寄存器 ECX 的值减为零。
main endp
end 

.code代码段的代码解释:

  • mov ecx,20:将寄存器 ECX 设置为 20,表示需要重复执行接下来的指令 20 次。

  • mov al,0cch:将寄存器 AL 设置为 0xCC(一个特殊值,通常用于填充内存以进行调试)。

  • mov edi,offset barray:将 EDI 寄存器设置为 barray 数组的地址。

  • rep stosb:将 AL 的值(0xCC)存储到 EDI 指示的内存位置,并将 EDI 增加1,然后将 ECX 减少1;重复此过程,直到 ECX 减为零,这将在 barray 数组的 20 个字节中全部填充 0xCC

未填充前:

填充后:数组对应的内存被填充未cc

http://www.lryc.cn/news/362005.html

相关文章:

  • Python画图(多图展示在一个平面)
  • python-web应用程序-Django数据库-操作表中的数据
  • 绕过WAF(Web应用程序防火墙)--介绍、主要功能、部署模式、分类及注入绕过方式等
  • 11.7 堆排序
  • Patchwork++:基于点云的快速、稳健的地面分割方法
  • Llama改进之——分组查询注意力
  • 英伟达开源新利器NV-Embed向量模型,基于双向注意力的LLM嵌入模型,MTEB 56项任务排名第一
  • JVM之【GC-垃圾清除算法】
  • 数据分析每周挑战——心衰患者特征数据集
  • 单例模式(Java实现)
  • 24.面向对象六大原则
  • Vue3-shallowRef与shallowReactive
  • CI/CD(基于ESP-IDF)
  • 聚观早报 | 东风奕派eπ008将上市;苹果Vision Pro发布会
  • k8s牛客面经篇
  • 第9周 基于MinIO与OSS实现分布式与云存储
  • 【Linux内核-编程指南】
  • Go 编程风格指南 - 最佳实践
  • awk的应用
  • 【网络原理】HTTP|认识请求“报头“|Host|Content-Length|Content-Type|UA|Referer|Cookie
  • 深入React Hoooks:从基础到自定义 Hooks
  • 9.7 Go语言入门(映射 Map)
  • 过期视频怎么恢复?如何从手机、电脑和其他设备中恢复?
  • LeetCode刷题第2题
  • mysql执行拼接的sql语句
  • 使用 pm2 或 screen 等工具来管理和后台运行你的 Node.js 应用
  • leetcode4 寻找两个正序数组的中位数
  • 水库大坝安全监测系统建设方案
  • 单片机的内存映射和重映射
  • 详解和实现数据表格中的行数据合并功能