每日一题(45)—— 字符数组找错
生活随笔
收集整理的這篇文章主要介紹了
每日一题(45)—— 字符数组找错
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
void test2()
{char str1[10], str2[10];int i;for(i=0; i<10; i++)str1[i] = 'a';strcpy( str2, str1 );
}
這段代碼有什么問題?
解答:如果面試者指出字符數組str1不能在數組內結束可以給3分;如果面試者指出strcpy(str2, str1)調用使得從str1復制到str2的字節數具有不確定性可以給7分,在此基礎上指出庫函數strcpy工作方式的給10分。
str1不能在數組內結束:因為str1的存儲為:{a,a,a,a,a,a,a,a,a,a},沒有'\0'(字符串結束符),所以不能結束
strcpy(char *s1,char *s2)他的工作原理是,掃描s2指向的內存,逐個字符付到s1所指向的內存,直到碰到'\0',因為str1結尾沒有'\0',所以具有不確定性,不知道他后面還會付什么東東。
正確應如下:
void test2() {char str1[10], str2[10];int i;for(i=0; i<9; i++){str1[i] = 'a'+i; //把abcdefghi賦值給字符數組}str[i]='\0';//加上結束符strcpy( string, str1 ); }
總結
以上是生活随笔為你收集整理的每日一题(45)—— 字符数组找错的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 8 9区别 endnote7_EndNo
- 下一篇: kindle刷机ttl_#原创新人#艰难