我正在阅读汇编代码,但我没有可用的源代码。程序集中有一个名为 next_text 的函数,我很难理解。谁可以帮我这个事?

      next_text()

       push   %rbp
       push   %rbx
       sub    $0x108,%rsp
       mov    %rdi,%rbp
       mov    %esi,%ebx
       jmp    <next_text+45>
   16  mov    %rbp,%rdx
       mov    $0x100,%esi
       mov    %rsp,%rdi
       callq  <fgets@plt>
       test   %rax,%rax
       jne    <next_text+42>
       callq  <func>
   42  sub    $0x1,%ebx
   45  test   %ebx,%ebx
       jg     <next_text+16>
       add    $0x108,%rsp
       pop    %rbx
       pop    %rbp
       retq

这里 %ebx 以某个大整数开头,比如 16000 。我对这个函数在做什么的理解是它需要一个参数,即文件流。然后它逐行读取文件。该行的最大长度为 100 hex,即 256 字符。然后将 ebx 减 1,只要文件足够长,就继续读取 16000 行的文件,最后当 ebx0 时,它​​退出。我的理解正确吗?另外,命令 sub $0x108,%rsp 在这里特别重要,还是只是设置堆栈内存?

最佳答案

在我看来是这样的:

void next_text(FILE *f, count) {
    char  buf[256];
    while (count-- > 0) {
        if (fgets(buf, sizeof buf, f)) {
            func();
        }
    }
}

关于c - 这个函数在汇编中的目的是什么?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/53440082/

10-15 03:12