精華區beta C_and_CPP 關於我們 聯絡資訊
剛測試一下 char *p[2] = {"12", "34"}; ... . ... . p[1] = "asfghj"; 這樣compile竟然會過!?!?@@ 因為char *ptr = "test"; 這樣ptr應該是無法再次被修改的 然而,p陣列的元素應該也是一個char型態的指標 為什麼卻可以被更改? 謝謝!! -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 140.112.90.235
L4ys:char *ptr = "test"; ptr可修改吧 是"test"所在記憶體區塊 10/19 13:34
L4ys:不能修改 10/19 13:35
purpose:置底4 10/19 16:16
tido868:Leaking? 10/19 23:10
> -------------------------------------------------------------------------- < 作者: EdisonX (卡卡獸) 看板: C_and_CPP 標題: Re: [問題] 指標陣列一問 時間: Sat Oct 19 13:35:14 2013 ※ 引述《NoStra ()》之銘言: : 因為char *ptr = "test"; 這樣ptr應該是無法再次被修改的 這誤會大了。 右邊你寫下了 "test" 時,最後在 hello.exe 會藏一個 "test" 的字串, 這叫 "字串常數" ,這字串不允許被改變,(廢話,都說是常數了) 但在寫 code 時看不出來那個配好的 "test", 估且稱它叫 const char * const __test; 而 char * ptr = "test" , 便是將 ptr 指向剛剛的那個 __test 的開頭位置, 但如剛所說的,這個 __test 不允許被改變,所以不能透過 ptr 去改變, 所以下面的動作是非法 for(int i = 0; ptr[i]!='\0' ; ++i) ptr[i] = '1'; 但卻可以透過 ptr , 去看 __test 裡面的內容,反正只要沒改到 __test 就好了 for(int i = 0; ptr[i]!='\0' ; ++i) cout << ptr[i] ; // printf("%c", ptr[i]); 換句話說,你可以將 ptr 指向其他的字串常數,變成下面形式 char * ptr = "test" ; ///< 會有一個看不到的 const char * const __test ptr = "Hello" ; ///< 將 ptr 指向另一個字串常數 ///< const char * const __Hello 你要指向其他地方幾次都隨便你,切記的是不能用已有的 char * ptr , 去改變程式裡已定義好的字串常數就行了, "除非",ptr 指向的空間,是你真的在程式碼裡面有宣告陣列給它用的。 char str[] = "STRING" ; ///< 在程式碼宣告一個字元陣列式的字串並給值 char * ptr = "test" ; ptr = "Hello"; ///< 合法,指向其他的地方,這地方是禁修改的區域 ptr[0] = '1' ; ///< 非法,不能透過 ptr 去修改 禁修改的區域 ptr = (char*)str ; ///< 合法,指向其他地方,這地方是程式裡宣告給的陣列 ptr[0] = '1' ; ///< 合法,修改到的地方是一開始就宣告存在的 其他零零碎碎的部份,再配合書本看一遍吧。 : 剛測試一下 : char *p[2] = {"12", "34"}; : ... . : ... . : p[1] = "asfghj"; : 這樣compile竟然會過!?!?@@ 這裡的 p[1] 本身也是一個 char * , 行為就和上面一樣,一開始讓它指向 "34" ( 看不到的 const char * const __34) , 後面讓它改著指向 "asfghj" (看不到的 const char * const __asfghj ) 只要不對 p[1] 所指的內容做修改就行。 : 然而,p陣列的元素應該也是一個char型態的指標 : 為什麼卻可以被更改? : 謝謝!!