亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

為什么這么寫不可以?

#include <stdio.h>

#include <string.h>

int main()

{

? ? char s1[100]="";

? ? char s2[]="我愛,";

? ? char s3[]="慕課網";

? ? strcat(s2,s3);

? ? strcpy(s1,s2);

? ??

? ??

? ? printf("%s\n",s1);

? ? return 0; ? ?

}


正在回答

2 回答

吐槽一下:本站應該把同類問題進行下歸類,顯示在相應課程中,因為用戶在發問前都不會先去搜索之前的答案...

正文:

首先,s1、s2 和 s3 都是什么:

s1是一個長度為100的字符數組。

s2是一個長度為4的字符數組。這是因為雖然你在聲明時沒有指定數組的長度,但是你用一個長度為4的字符串初始化s2,所以編譯器自動將s2的長度確定為4。

s3是一個長度為4的字符數組。道理同上。

再說strcat函數會干什么:

strcat(s2, s3) 這個函數是將s3中的內容(包括s3結尾的'\0')復制到s2中最后一個字符的后面(覆蓋掉s2原來結尾的'\0'),這樣就能把兩個字符串中的字符連起來了,并且還是'\0'結尾。

注意:這就需要s2有足夠的長度來容納這么多的字符,長度至少為?strlen(s2) + strlen(s3) + 1,最后這個1就是結尾的'\0'。

但是你的s2長度只有4,所以寫越界了。在調用用strcat、strcpy之類的函數時一定要注意是否有足夠的存儲空間來容納你要操作的字符。如果你越界了,你的代碼是可以編譯通過的,但在運行的時候很可能就會發生錯誤,這就是所謂的“緩沖區溢出”錯誤,可能會引起嚴重的問題。

在本站的這個題目中,它看到你寫了 strcat(s1, ...) 這樣的代碼才算對,因為s1的空間足夠多。


最后提示下:本站帖子里有格式化代碼的功能,你可以不用手打代碼格式。

3 回復 有任何疑惑可以回復我~
#1

Pheromone 提問者

謝謝你的回答,同時謝謝你的友情提示。
2015-07-13 回復 有任何疑惑可以回復我~
#2

章然

請問一個中文字占多少字符的?
2015-07-14 回復 有任何疑惑可以回復我~
#3

章然

還有,strcat(s1,s2)可行嗎?
2015-07-14 回復 有任何疑惑可以回復我~
#4

onemoo 回復 章然

這個問題就復雜了... 有很多的語言需要編碼,各國針對自己的語言文字創造了很多的字符集。過去網頁上常遇到的“亂碼”就是因為字符集不匹配。 但是有這么多的字符集還是不方便使用,所以就創造了Unicode。目標就是把所有語言的所有字符以及符號都統一編碼。 光有規劃好的字符集方案也是不夠的,計算機得用一種方法把字符的編碼記錄下來,這就是字符集編碼。Unicode編碼有UTF-32 UTF-16 UTF-8,目前最常用也是最推薦使用的就是UTF-8編碼。 UTF-8是一種變長編碼,一般一個中文字占用3-4個字節
2015-07-14 回復 有任何疑惑可以回復我~
#5

onemoo 回復 章然

strcat(s1, s2) 是可行的,s1足夠容乃s2中的字符。
2015-07-14 回復 有任何疑惑可以回復我~
#6

飛少legender

#include <stdio.h> #include <string.h> int main() { char s1[100]=""; char s2[]="我愛,"; char s3[]="慕課網"; /*在以下補全代碼*/ strcat(s2,s3); printf("%s\n",s2); //strcpy(s1,s2); //strcat(s1,s3); //printf("%s\n",s1); return 0; }為何這樣寫能運行出結果,而并沒有顯示越界。請指教!
2015-09-28 回復 有任何疑惑可以回復我~
#7

飛少legender

#include <stdio.h> #include <string.h> int main() { char s1[100]=""; char s2[]="我愛,"; char s3[]="慕課網"; /*在以下補全代碼*/ strcat(s2,s3); printf("%s\n",s2); return 0; }為什么這樣寫可以運行出結果,而并沒有顯示溢出。求指教!
2015-09-28 回復 有任何疑惑可以回復我~
#8

onemoo 回復 飛少legender

在編譯時C語言并不會對溢出進行檢測,所以這代碼可以正常通過編譯。 這個代碼在運行時肯定會發生溢出的,但如果溢出的部分并沒有覆蓋到其他重要的數據的話,是可能不會引起崩潰的。 但這是非常危險的代碼,有嚴重的安全隱患,現實中絕對不要這樣寫!
2015-09-29 回復 有任何疑惑可以回復我~
查看5條回復

我也是這么干的

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

為什么這么寫不可以?

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號