gpt4 book ai didi

c - 如何更改处理器堆栈?

转载 作者:行者123 更新时间:2023-12-04 12:01:02 25 4
gpt4 key购买 nike

为什么这段代码不打印“test”?

#include <stdio.h>
#include <stdlib.h>

void foo ( void ) {
printf("test\n");
}

__declspec(naked)
void bar ( void ) {
asm {
push 0x000FFFFF
call malloc
pop ecx
push eax
add eax, 0x000EFFFF

mov ecx, esp
mov esp, eax
push ecx

call foo

pop esp
call free
pop ecx
ret
}
}

int main(int argc, char* argv[])
{
bar();
return 0;
}

最佳答案

因为您新分配的堆栈不是 DWORD 对齐的。将代码更改为:

  push 0x00100000
call malloc
pop ecx
push eax
add eax, 0x000f0000

... 它将根据需要打印。

按照 Paul 的建议,务必添加\n 以避免出现缓冲问题。

关于c - 如何更改处理器堆栈?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/831107/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com