这对我有用gcc version 4.2.1 (Based on Apple Inc. build 5658) (LLVM build 2336.11.00)
:
char path[100];
printf("Give a path: ");
// Max length of 99 characters; puts a null terminated string in path, thus 99 chars + null is the max
scanf("%99s", path);
printf("This is your path: %s\n", path);
在 *nix 机器上,在汇编中,读取和写入:
read: mov $0x03, %rax # Syscall Read
mov $0x00, %rbx # Stdin
mov $Buff, %rcx # Address to read to
mov $BuffLen, %rdx # Bytes to read
int $0x80 # Call
write: mov $0x04, %rax # Syscall Write
mov $0x01, %rbx # Stdout
mov $Buff, %rcx # Address to write from
mov $BuffLen, %rdx # Bytes to write
int $0x80 # Call
这是我从老师那里得到的一些 Windows 程序集:
.386
.MODEL FLAT
ExitProcess PROTO NEAR32 stdcall, dwExitCode:DWORD
GetStdHandle PROTO NEAR32 stdcall, nStdHandle:DWORD
ReadFile PROTO NEAR32 stdcall, hFile:DWORD, lpBuffer:NEAR32, NumberOfCharsToRead:DWORD,
lpNumberOfBytesRead:NEAR32, lpOverlapped:NEAR32
WriteFile PROTO NEAR32 stdcall, hFile:DWORD, lpBuffer:NEAR32, NumberOfCharsToWrite:DWORD,
lpNumberOfBytesWritten:NEAR32, lpOverlapped:NEAR32
STD_INPUT EQU -10
STD_OUTPUT EQU -11
cr EQU 0dh
Lf EQU 0ah
.STACK
.DATA
InMsg BYTE 14 dup (?)
msgLng DWORD $ - InMsg ;
read DWORD ?
written DWORD ?
hStdIn DWORD ?
hStdOut DWORD ?
.CODE
_start:
INVOKE GetStdHandle, STD_INPUT
mov hStdIn, eax
INVOKE ReadFile, hStdIn, NEAR32 PTR InMsg, msgLng, NEAR32 PTR read, 0
INVOKE GetStdHandle, STD_OUTPUT
mov hStdOut, eax
INVOKE WriteFile, hStdOut, NEAR32 PTR InMsg, msgLng, NEAR32 PTR written, 0
INVOKE ExitProcess, 0
PUBLIC _start
END