如题 K&R 中的 一个strcpy函数中出现的方式
void strcpy(char *s, char *t)
{
while (*s++ = *t++);
}
如题 K&R 中的 一个strcpy函数中出现的方式
void strcpy(char *s, char *t)
{
while (*s++ = *t++);
}
void v(char *s, char *t) {
*s++ = *t++;
}
看一下对应指令
push %rbp
mov %rsp,%rbp
mov %rdi,-0x8(%rbp) //参数1 s
mov %rsi,-0x10(%rbp) //参数2 t
mov -0x10(%rbp),%rax //t暂存%rax
movzbl (%rax),%edx //*t放入%edx
mov -0x8(%rbp),%rax //s暂存%rax
mov %dl,(%rax) //*t的低8位,即一个字节,放入*s
addq $0x1,-0x8(%rbp) //s++
addq $0x1,-0x10(%rbp) //t++
leaveq
retq
可以看到,先*s = *t,然后s和t各自加1
1 回答1.4k 阅读
1 回答1.1k 阅读
1 回答933 阅读
874 阅读
818 阅读
737 阅读
686 阅读
首先是
然后判断整个表达式的值是否为真,即
满足,则继续循环,否则终止
不论循环继续与否,接下来要执行
=================================
回答评论中补充的问题,程序怎么读
优先级表我就不贴了,百度一大堆 ,核心是你要理解下面流程中的
5.2
*
,判断为指针运算符号,需要一个标示符或者表达式s
,是一个合法的标示符,继续搜索是否有更高优先级的运算符++
,由于*
与++
是同一优先级,结合性为右到左,所以等同于*(s++)
=
,判断为赋值运算符,优先级比++
低,因此前面的部分可以直接进行计算*(s++)
怎么计算?expr1 = s++; expr2 = *expr1;
expr1 = s++
,后置++
的含义是先使用变量/表达式的值、再自增,表达式s++
的计算结果就是s
的值,计算完毕后,s
自增1,也就是说假如s = 1
,那么s++
这个表达式
的计算结果就是1
,expr1 = 1
,计算完毕后,s
的值自增1变为2
,但不影响之前已经计算完毕的表达式expr2 = *expr1
,按照上面所举的例子,此时s=2
,expr2 = *1
=
的计算,由于赋值运算符是双目运算,需要一个右目表达式,继续解析*
的优先级比=
高,因此先计算*t++
,原理同上a=b
的值就是b
非0