strcpy的分析

/*
mov 7EFEFEFF  edx
h3         h2             h1             h0
01111110 11111110 11111110 1111111-->
4个0代表4个判断标志 h3  h2 h1 h0
//eax   包含4个字节 每个字节 0-7包含8位
b3(0-7)       b2(0-7)    b1(0-7)     b0(0-7)
xxxxxxxx  xxxxxxxx   xxxxxxxx  xxxxxxxx

b(i) = 0
b0 = 00000000       ->  h0 = b1(0)
b1 = 00000000       ->  h1 = b2(0)
b2 = 00000000       ->  h2 = b3(0)
b3 = 00000000       ->  h3 = b3(7)
b(i) !=0 时候 会产生进位
b0 ! = 0000000      ->h0 = b1(0)+1
b1 ! = 0000000      ->h1 = b2(0)+1
b2 ! = 0000000      ->h2 = b3(0)+1
b3 ! = 0000000      ->h3 = b3(7)+1
xor eax,edx
eax
b3(0-7)       b2(0-7)    b1(0-7)     b0(0-7)
b3(7)xxxxxx b3(0)  xxxxxxxb2(0)   xxxxxxxb1(0)  xxxxxxxx
edx
h(3)111111h(2) 1111111h(1) 1111111h(0) 1111111
b1(0) = b1(0) xor h(0)
b2(0) = b2(0) xor h(1)
b3(0) = b3(0) xor h(2)
b3(7) = b3(7) xor h(3)

b(i) = 0
=>
b1(0) = b1(0) xor b1(0) = 0
b2(0) = b2(0) xor b2(0) = 0
b3(0) = b3(0) xor b3(0) = 0
b3(7) = b3(7) xor b3(7) = 0

b(i) != 0
bi(0) = 0 或者 =1
b1(0) = b1(0) xor  (b1(0)+1)
b2(0) = b2(0) xor  (b2(0)+1)
b3(0) = b3(0) xor  (b3(0)+1)
b3(7) = b3(7) xor  (b3(7)+1)

b1(0) = b1(0) xor  (b1(0)+1)
b1(0) = 0
=> b1(0) = 0 xor(0+1) = 0 xor 1 = 1
b1(0) = 1
=> b1(0) = 1 xor(1+1) = 1 xor 0 = 1
b1(0) = 1

b2(0) = 1
b3(0) = 1
b3(7) = 1

xor eax,0FFFFFFFFh
b1(0) = not b1(0)
b2(0) = not b2(0)
b3(0) = not b3(0)
b3(7) = not b3(7)
bi  = 0     => bi  = 1
bi  = 1    => bi   = 0
现在从头到这里看下数据
传入的数据
b0 = 0  -> b1(0) = 1
b1 = 0  -> b2(0) = 1
b2 = 0  -> b3(0) = 1
b3=  0  -> b3(7) = 1

b0 != 0  -> b1(0) = 0
b1 != 0  -> b2(0) = 0
b2 != 0  -> b3(0) = 0
b3 != 0  -> b3(7) = 0
test eax,81010100h
//81010100h
1000 0001 0000 0001  0000 0001 0000 0000

je  loop;             // ZF = 1

bi(0)全为0的条件是b0  b1 b2 b3 都不为0

je/jz 是 当运算结果为0时则跳，也就是当ZF标志为1时跳转。
ZF标志为1，说明上一次运算（不管是算术运算还是逻辑运算）结果为0，

//test eax, 100b;          b后缀意为二进制
// jnz  ******;             如果eax右数第三个位为1,jnz将会跳转
*/

bool c0(int d)

{

_asm
{

main_loop:
lea ecx,d
mov edx,7EFEFEFFh
mov         eax,dword ptr [ecx]
xor eax,edx
xor eax,0FFFFFFFFh
test eax,81010100h
mov edx,[ecx]
je      short main_loop_out
//; found zero byte in the loop
//; main_loop_end:
test    dl,dl               ; is it byte 0
je      short byte_0
test    dh,dh               ; is it byte 1
je      short byte_1
test    edx,00ff0000h       ; is it byte 2
je      short byte_2
test    edx,0ff000000h      ; is it byte 3
je      short byte_3
jmp     short main_loop     ; taken if bits 24-30 are clear and bit
; 31 is set
byte_3:
ret
byte_2:

ret
byte_1:

ret
byte_0:
ret
main_loop_out:
//不包含0字节
ret
}

};

• 本文已收录于以下专栏：

strcpy函数详解

strcpy(s1,s2);strcpy函数的意思是：把字符串s2中的内容copy到s1中，连字符串结束标志也一起copy. 这样s1在内存中的存放为：ch\0; 在cout 如果说s1的长...
• u014744118
• 2015年10月09日 10:37
• 1860

使用strcpy的注意事项

• stoneboy100200
• 2012年09月07日 10:17
• 2288

strcpy的参数

strcpy我们应该是经常用的，C语言的基本函数，该函数的第一个参数是
• ma2595162349
• 2017年07月28日 17:40
• 806

strcpy函数实现的几种方式

C/C++——strcpy函数的实现 和解析 题目：      已知strcpy函数的原型是：          char * strcpy(char * strDest,const char ...
• liusandian
• 2016年08月17日 16:54
• 465

实现C库函数strcpy

1 实现c库的函数strcpy原型声明：char* strcpy(char* dst, const char* src);普通版本的strcpy//strcpy 实现没有检查dst和src内存重叠问题...
• renwotao2009
• 2016年10月18日 22:33
• 673

strcpy源代码汇总

1,微软实现 C:\Program Files\Microsoft Visual Studio 10.0\VC\crt\src\strcat.c char * strcpy(char * ...
• u013354805
• 2015年11月26日 16:57
• 1792

写程序实现自己的strcpy() 函数

• robinsongsog
• 2014年03月21日 18:38
• 1285

C/C++——strcpy函数的 几种 实现 和 详细 解析

C/C++——strcpy函数的实现 和解析 题目：      已知strcpy函数的原型是：          char * strcpy(char * strDest,const char * s...
• wconvey
• 2014年03月13日 07:39
• 29182

strcpy_s与strcpy安全性的比较

• baodi_z
• 2007年07月17日 11:29
• 4651

【面试题】strcpy的严格实现

• jianxiong8814
• 2007年06月05日 23:04
• 1317

举报原因： 您举报文章：strcpy的分析 色情 政治 抄袭 广告 招聘 骂人 其他 (最多只允许输入30个字)