#include<stdio.h>
int main(){
char a[10]="xiaoming";
char b[10]={'\0'};
int k=0,i=0;
while(a[k]!='\0'){
b[k++]=a[k];
}
printf("%s",b);
return 0;
}
这一串代码输出的结果为:
我们看到会丢失首字符,原因是因为在进行b[k++]=a[k]时,系统会首先去寻找b[k++]的地址,在第一次也就是去寻找b[0]的地址,但是k++的使用为当k变量被使用后,k会立刻增加1,此时右边就变成了a[1],也就是说系统在此次赋值时,会首先去找到左边数组的地址,然后将右边的值复制在左边的地址所代表的内存空间中,在找左边数组地址时使用了k,导致了k+1,因此右边变成了a[1],也就是第一次循环时b[0]=a[1].
解决此办法是讲k++移到下边来即可。
#include<stdio.h>
int main(){
char a[10]="xiaoming";
char b[10]={'\0'};
int k=0,i=0;
while(a[k]!='\0'){
b[k]=a[k];
k++;
}
printf("%s",b);//"xiaoming"
return 0;
}