K&R之类以及许多资料中都有提及如下字符串复制算法:
int cpy_str(char *dst,const char *src) { while(*dst++=*src++); }如下是更简单的一种情况:
#include<stdio.h> #include<stdlib.h> int main(void) { int i = 0,j=0,k = 3; printf("i=%d,k=%d j=%d\n\n",i,k,j); while (j=k--) {//《《《《***焦点在这里***《《《《《 i++; printf("i=%d,k=%d j=%d\n", i, k, j); } printf("\ni=%d,k=%d j=%d\n", i, k, j); system("pause"); return 0; }运行结果为:
i=0,k=3 j=0 i=1,k=2 j=3 i=2,k=1 j=2 i=3,k=0 j=1 i=3,k=-1 j=0 请按任意键继续. . .如上第二行表明,k–在j=k之后发生 如上末行i表明,循环条件判断发生在k–之后;
以上2条总结为:循环条件判断总在表达式完成运算之后以左值为准;
优先级顺序:’=’ >’–’(后置)>条件判断(左值);