有人可以解释为什么我的strcat会这样做吗?
我似乎无法找出为什么我要重写源字符串的一部分。
输出如下:New String:HelloThis应该在str1中str1h 0的反斜杠0之后
global strcat
extern strlen
strcat的:
push ebp
mov ebp, esp
push ecx
push esi
push edi
push ebx
push edx
xor edx, edx
xor edi, edi
xor ebx, ebx
xor esi, esi
xor ecx, ecx
mov edi, [ebp + 8]
mov esi, [ebp + 12]
push edi
call strlen
pop edi
mov ecx, eax
xor eax, eax
push esi
call strlen
pop esi
mov ebx, eax
xor eax, eax
cmp [edi + ecx], byte 0b
je PUT_LINE
jmp FINALIZE_END
PUT_LINE:
cmp ebx, eax
je END
mov dl, [esi + eax]
mov [edi + ecx], dl
xor edx, edx
inc eax
inc ecx
jmp PUT_LINE
END:
mov eax, [ebp + 8]
jmp FINALIZE_END
FINALIZE_END:
pop edx
pop ebx
pop edi
pop esi
pop ecx
mov esp, ebp
pop ebp
ret
〜
〜
int main(int argc, char** argv)
{
(void)argc;
(void)argv;
char* str1;
char* str2;
str1 = strdup("Hello");
str2 = strdup("This shall be after my backslash 0 in str1");
printf("New String : %s\n", strcat(str1, str2));
return (0);
}
〜
答案 0 :(得分:4)
strcat()
将一个字符串中的字符附加到另一个字符串。目标字符串已修改。因此strcat(str1, str2)
修改str1
以包含str2
。
由于没有为str1
分配足够的内存来包含两个字符串中的字符,因此会导致溢出。