所以我正在阅读有关如何创建结构的手册..
一开始,我是这样做的:
struc point X, Y
{
.X dw X
.Y dw Y
}
section '.code' code readable executable
main:
push ebp
mov ebp,esp
PP Point 0, 0 ;Crashes here..
mov esp, ebp
pop ebp
mov eax, 0x0
ret
所以我想得很好,因为它是一个局部变量,我需要sub esp, sizeof(Point)
而且我做到了,但它仍然崩溃了..
所以我在 Point 结构中完成了它,而不是崩溃,它现在被删除了:
section '.data' data readable writeable
Response db 13, 10, "Value: %d", 13, 10, 0
struc Point X, Y
{
sub esp, 0x8
mov dword[esp + 0x00], X
mov dword[esp + 0x04], Y
}
section '.code' code readable executable
main:
push ebp
mov ebp,esp
PP Point 0, 0 ;create a point
push PP
call Point_Valid
add esp, 0x04
mov esp, ebp
pop ebx
call [getchar]
mov eax, 0x00
ret
Point_Valid:
push ebp
mov ebp, esp
mov eax, [ebp + 0x8]
push eax ;Not sure how to get Point from eax or Point.X..
push Response
call [printf]
add esp, 0x08
mov esp, ebp
pop ebp
ret
但是,上述操作不仅失败,还会触发:
从 Malware Defender for Windows 8.1 中
我不明白为什么:S 但它只发生在我sub esp
在结构中使用时。如果我使用.X dw X
它只会崩溃但不会触发恶意软件防御者。
有什么想法可以实现将点传递给函数吗?或者创建一个本地点并将其传递给一个函数以及访问它的字段?