Intel汇编-递增传送字符串

# An example of the MOVS instructions (递增传送字符串)
#
# MOVS    把字符串从一内存位置传送到另一个内存位置的简单途径。
# movsb : 8bit
# movsw : 16bit
# movsl    : 32bit
#
# MOVS使用隐含的源和目标操作数。
# 隐含的源操作数是ESI寄存器,它指向源字符串的内存位置。 ESI(S)->source
# 隐含的目标操作数是EDI寄存器,它指向字符串要被复制到的目标内存位置。EDI(D)->destination
#
# 每次执行MOVS时,数据传送后,ESI和EDI寄存器会自动改变,为另一次传送做准备。但有时候这会变得有些难于处理。
# ESI和EDI自动传递增,也可能自动传递减,这取决于EFLAGS寄存器中的DF标志。
# DF清零, 增, DF被设置,减。
#
# CLD 用于将DF标志清零
# STD 用于设置DF标志
#
#
# 两种方式加载ESI、EDI值。
# 间接寻址:通过在内存位置标签前面添加美元符号,内存位置的地址被加载到ESI或EDI寄存器中
# movl $output, %ed        # 把output标签的32位内存位置传送给EDI
#
# LEA:加载一个对象的有效地址。
# leal output, %edi
#
    .section .data
value1:
    .ascii "This is a test string.\n"

    .section .bss
.lcomm output, 23

    .section .text
    .globl main
main:
    nop
    leal value1, %esi
    leal output, %edi
    movsb
    movsw
    movsl

    movl $1, %eax
    movl $0, %ebx
    int $0x80

# gcc -g -o 01 01-movs.s -m32
#
# (gdb) b 31
# Breakpoint 1 at 0x119e: file 01-movs.s, line 31.
# (gdb) r
# Breakpoint 1, main () at 01-movs.s:31
# 31              leal value1, %esi
# (gdb) s
# 32              leal output, %edi
# (gdb) s
# 33              movsb
# (gdb) x/x &output
# 0x56559028 <output>:    0x00000000
# (gdb) x/s &output
# 0x56559028 <output>:    ""
# (gdb) s
# 34              movsw
# (gdb) x/s &output
# 0x56559028 <output>:    "T"
# (gdb) s
# 35              movsl
# (gdb) x/s &output
# 0x56559028 <output>:    "Thi"
(gdb) s
# 37              movl $1, %eax
# (gdb) x/s &output
# 0x56559028 <output>:    "This is"

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
比较字符串汇编实现可以通过逐个比较字符串中每个字符的 ASCII 码值来完成。 假设要比较的两个字符串分别存放在 `str1` 和 `str2` 中,比较结果存放在 `result` 中,可以按照以下步骤实现: 1. 初始化比较结果为相等(`result = 1`)。 2. 逐个比较 `str1` 和 `str2` 中每个字符的 ASCII 码值,如果不相等则将比较结果设为不相等(`result = 0`)。 3. 如果其中一个字符串结束了,即遇到了字符串结束符 `\0`,则停止比较,并检查另一个字符串是否也已经结束,如果没有结束则将比较结果设为不相等(`result = 0`)。 具体实现可以参考以下汇编代码: ```assembly ; 比较字符串 str1 和 str2,结果存放在 result 中 ; str1 和 str2 的地址分别存放在 si 和 di 中,比较结果存放在 result 中 compare: mov al, [si] ; 取出 str1 中的字符 mov bl, [di] ; 取出 str2 中的字符 cmp al, bl ; 比较两个字符 jne unequal ; 如果不相等则跳转到 unequal 标签 cmp al, 0 ; 检查是否遇到了字符串结束符 je done ; 如果是则停止比较 inc si ; si 指向下一个字符 inc di ; di 指向下一个字符 jmp compare ; 继续比较下一个字符 unequal: mov result, 0 ; 将比较结果设为不相等 done: ret ``` 在这个例子中,程序使用 `si` 和 `di` 分别存放两个字符串的地址,使用 `al` 和 `bl` 分别存放两个字符串中当前比较的字符。`result` 存放比较结果,初始化为相等。 程序逐个比较两个字符串中的字符,如果不相等则将比较结果设为不相等。如果其中一个字符串结束了,则停止比较,并检查另一个字符串是否也已经结束,如果没有结束则将比较结果设为不相等。最后返回比较结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值