微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

WriteConsole在MASM中返回false

如何解决WriteConsole在MASM中返回false

我正在尝试创建一个数组,并访问它的值并打印出来

调用WriteConsole子例程后,它返回false,但是提供了所有值。在这里我们可以看到-https://imgur.com/a/vUfwOo6 调用WriteConsole后,Eax寄存器为0。在这里,您可以看到被压入堆栈的寄存器值。 https://imgur.com/a/gv6s4uG 考虑到WriteConsole是WINAPI子例程,这意味着它是stdcall。因此,我从右到左传递值

lpReserved -> 0
lpNumberOfCharsWritten -> offset to 00403028 (CharsWritten variable)
nNumberOfCharsToWrite -> Just 2,because in array only ints are present of length 2
*lpBuffer -> ebx register,which contains array lvalue
hConsoleOutput -> Output from GetStdHandle (In this case -> edx register -> A0)

我的MASM代码

.386
.model flat,stdcall
option casemap:none
include \masm32\include\windows.inc
include \masm32\include\kernel32.inc
includelib \masm32\lib\kernel32.lib
include \masm32\include\user32.inc
include C:\masm32\include\masm32.inc
includelib C:\masm32\lib\masm32.lib
includelib \masm32\lib\user32.lib
includelib \masm32\lib\msvcrt.lib ; Some default includes :P

.data

dArray              dd  10 dup (?)      ; Main array
CharsWritten        dd ?
LoopCounter         dd 0
StdHandle           dd ?
.code


PrintArrayToScreen proc

mov eax,STD_OUTPUT_HANDLE
push eax
call GetStdHandle

mov StdHandle,eax
mov eax,[LoopCounter]
innerPrintLoop:
mov ecx,offset dArray
mov eax,[LoopCounter]
mov ebx,[ecx + eax * 4]
mov esi,offset CharsWritten

push 0
push esi
push 2
push ebx
mov edx,StdHandle
push edx

call WriteConsole

mov eax,[LoopCounter]
inc eax
mov LoopCounter,eax ; Storing the Loop Counter in the variable
cmp eax,11  ; +1 because of loop counter increment
jnz innerPrintLoop
ret
PrintArrayToScreen endp

arrayLoop proc          ; Subroutine for the array filling
mov eax,offset dArray
mov bx,10
mov ecx,0
innerLoop:
mov [eax + ecx * 4],bx  ; ecx * 4 => counter * 4 bytes
inc bx
add ecx,1
cmp ecx,10
jne innerLoop
mov eax,offset dArray
ret
arrayLoop endp

start:
call arrayLoop
call PrintArrayToScreen
mov eax,0
push eax
call ExitProcess
end start

解决方法

the documentationWriteConsole

lpBuffer [in]
指向缓冲区的指针,该缓冲区包含要写入控制台屏幕缓冲区的字符。

因此,您应该传递要写入的数据的地址,但实际上是传递数据本身。

您可以通过将行mov ebx,[ecx + eax * 4]更改为lea ebx,[ecx + eax * 4]来“修复”该错误。但是请注意,WriteConsole不会为您执行任何整数到字符串的转换,因此您仍然可能无法获得预期的结果。如果您需要那种功能,请使用printf

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。