對deprecated conversion from string constant to 'char *'此類警告的詳細(xì)解釋 假定你想使用一個char*類型的變量,有時指向一個字符串,有時指向另外一個字符串。開始的代碼就像這樣: char *msg; msg = "hello"; msg = "good-bye"; 編譯器會對這段代碼給出兩段警示,說”deprecated conversion from string constant to 'char *'",意思就是說你沒有能力修改字符串的內(nèi)容。如果將代碼寫成這樣,如: char *msg = "hello"; *msg = 'j'; printf( "%s\n", "hello" ); 編譯器會通過編譯,實(shí)際上會將msg指向的內(nèi)容從"hello"轉(zhuǎn)變?yōu)?jello", 正確的解決方法是將jmsg聲明為一個指向不變字符串的指針: const char *msg; msg = "hello"; msg = "good-bye"; 這段代碼可以成功編譯,并且將msg指向的值如愿改變,但如果你將指針指向的指進(jìn)行賦值: *msg = 'j'; 將會產(chǎn)生一個錯誤,不能修改一個字符串常量 注意如下的代碼,此代碼編譯時不會出現(xiàn)警告也不會出現(xiàn)任何錯誤: const char *msg; char buf[ 10 ]; sprintf( buf, "%03d\n", 7 ); msg = buf; 改變buf的內(nèi)容是可以的,因?yàn)樗]有被聲明為常量。在這種情況下,msg將指向一個字符串,"007\n". 像這種語句 *buf = 'x'; 將會正確編譯執(zhí)行,但像 *msg = 'x'; 將會產(chǎn)生一個警告,因?yàn)閙sg指向的內(nèi)容不允許改變 還有一種方法是使用強(qiáng)制轉(zhuǎn)換,使用強(qiáng)制轉(zhuǎn)換意味著你清楚會出現(xiàn)什么情況,不需要編譯器為你做出判斷,例如下面的代碼將不會產(chǎn)生警告: char *msg; msg = (char *) "hello"; 但一旦你使用強(qiáng)制轉(zhuǎn)換,編譯器對如下語句進(jìn)行編譯時,也不會出現(xiàn)錯誤或警告 *msg = 'j'; 這個錯誤將一直存在,但并不會被發(fā)現(xiàn),直到運(yùn)行時。那時再找出錯點(diǎn)就相當(dāng)麻煩了,比編譯器提醒你,麻煩多了。所以,最好不要對字符串使用強(qiáng)制轉(zhuǎn)換。 Constant 指針 根據(jù)constant的位置不同,可以有以下四種情況: const char* const msg_0; const char *msg_1; char* const msg_2; char *msg_3; 其中,msg_0是一個constant指針指向一個const字符串。這個聲明編譯器會給出一個警告,因?yàn)閙sg_0的指向沒有被初始化,而且之后的語句也無法對mg_0進(jìn)行賦值,如 const char const *msg_0 = "hello"; 會編譯成功,但 *msg_0 = 'j';或者 msg_0 = "good-bye"; 將會產(chǎn)生錯誤 msg_1既可以指向一個const字符串,也可以指向一個可變的字符串,但是不能修改它所指向的字符串的內(nèi)容。 編譯msg_2這條語句,會出現(xiàn)和編譯msg_0一樣的錯誤。因?yàn)橹羔樖且粋€常量,所以它應(yīng)該首先被賦值。如果剛開始已經(jīng)賦值,那么它可以對指向的字符串內(nèi)容進(jìn)行修改,如: char buf[ 10 ]; char const *msg_2 = buf; 這段代碼里,msg_2指向buf[0],并且永遠(yuǎn)指向這個地址,不會改變; 對于msg_3,就沒太多可以說的。你可以改變指針,也可以改變指針指向的內(nèi)容 |
|