当前位置: 首页 > 知识库问答 >
问题:

使用堆栈的值作为指针的汇编x86?

穆德海
2023-03-14

我想知道如何将指针参数传递给过程?

我必须创建具有2个参数的函数:

  1. 单词数组
  2. 数组的大小

该函数获取数组的大小并对列求和。

这就是我所编码的:

.MODEL  Small
.STACK  64

; +===============================+
; |             DATA              |
; +===============================+

.DATA 
array1      dw  1,2,3,4
array1size  dw  4
result      dw  ?
address     dw  ?
; print
TMP     dw  0 ; general temporary variable ..
.code

addNumbers proc
;   reset result
    lea di,result
;   use stack
    mov bp,sp
;   get num array
    mov bx,[bp+2]
;   get num of numbers
    mov cx,[bp+4]
; making additiontion
adding:
    add [di],bx
    inc bx; go to the next bx
loop adding
    ret 2
endp

; start
start:
    mov ax,@DATA
    mov ds,ax
; set strings
    push array1size
    push offset array1
    call addNumbers
; print
    mov dx:ax,result
    call printNumber
    mov ah,4ch
    mov al,0
    int 21H
end start

问题 - 它正在添加偏移指针(这里是cs:0000,cs:0001cs:0002cs:0003)而不是偏移值(这里是:1234)。

因此,结果将为 6 而不是 10。

有人能帮我吗?

共有1个答案

赏开宇
2023-03-14
INC BX

当然会在BX的指针上加1(字节)。如果需要移动一个字,就要加上字的大小。假设是2个字节,那么你需要

ADD BX, 2

而不是INC

你的另一个问题是,你没有添加指向的值,[BX],而是指针本身BX。您可以使用备用寄存器(如 AX)来计算总和。

    MOV  AX,0
adding:
    ADD  AX,[BX]
    ADD  BX,2
    LOOP adding
    MOV  [result],AX

    RET  4
 类似资料:
  • 问题内容: 在Linux(Debian和Ubuntu)中,如何在C的堆栈指针处输出当前值? 我尝试了google,但未找到任何结果。 问题答案: 不能移植甚至不能保证正常工作的一个技巧是简单地打印出本地地址作为指针。 这实际上将打印出其地址与当前堆栈指针的近似值

  • 所以我有一个堆栈,它允许典型的Push和Pop函数。我很难理解这一切实际上是如何在代码方面工作的。我在这里看到了这篇文章,最佳答案中的图片/图表,展示了列表是如何被“推”下来的,你指向最新的元素。我有一个 它挂接到结构“节点” 我如何结合一个推拉与"节点*下一步;"?最难理解的是我将如何真正做到这一点。我知道它最初指向空,然后如果我推一个2,4,6,它将是6,4,2,#。掌握如何实际使用链表中的指

  • 问题内容: 在C语言中,当我从函数返回堆栈创建的变量的指针时,在函数返回后内存将被丢弃,从而使指针无法取消引用。但是在Go中,编译器没有给我任何错误。这是否意味着这样做是安全的? 问题答案: 是的,这是安全的,并且是Go编程中的常规模式。Go使用转义分析来移动带有指针的所有值,这些指针会自动将栈转义到堆。您无需担心在何处分配值。 从Go常见问题解答中:“我如何知道是在堆还是在堆栈上分配了变量?”

  • 问题内容: 当我发现一些奇怪的东西时,我正在玩一些代码: 对我来说奇怪的是变量i地址的变化。 我的猜测是内核提供了不同的堆栈起始地址来尝试阻止某种破解。真正的原因是什么? 问题答案: 正是由于这个原因,在多个操作系统上使用了地址空间布局随机化。堆栈指针地址的变化很可能是由这种情况引起的- 在最新版本的Linux和/或* BSD上很可能是这种情况。IIRC Windows的最新版本也可以做到这一点。

  • 本文向大家介绍堆和栈上的指针有什么区别?相关面试题,主要包含被问及堆和栈上的指针有什么区别?时的应答技巧和注意事项,需要的朋友参考一下 指针所指向的这块内存是在哪里分配的,在堆上称为堆上的指针,在栈上为栈上的指针. 在堆上的指针,可以保存在全局数据结构中,供不同函数使用访问同一块内存. 在栈上的指针,在函数退出后,该内存即不可访问.

  • 6、堆栈操作指令(StackOperation Instruction) 堆栈是一个重要的数据结构,它具有“先进后出”的特点,通常用来保存程序的返回地址。它主要有两大类操作:进栈操作和出栈操作。 1)、进栈操作 、PUSH(Push Word or Doublewordonto Stack) 指令格式:PUSH Reg/Mem PUSH Imm;80286+ 一个字进栈,系统自动完成两步操作:SP