作者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型态的指标
: 为什麽却可以被更改?
: 谢谢!!
--
就算把新鲜的肝拿回去,还是一样写码到秃头,加班到天亮,
永远当老板的傀儡 你是不是想这麽做?
是的话你就拿回去~ 拿啊!!
九世宅男 : 下辈子不要再让我干工程师了 ~
< Kuso 星爷语录 >
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 180.177.73.52
1F:推 NoStra:所以是 const char* 跟 char* const ptr的差异罗? 10/19 13:44
是
const char * ptr 指的是指向对向不能被修改;
char * const ptr 指的是不能再指向其他地方;
const char * const ptr ; 指的是不能被修改也不能指向其他地方。
所以一开始我上文写的 const char * __test 应该是 const char * const __test
较合意正确 (修过) 。
※ 编辑: EdisonX 来自: 180.177.73.52 (10/19 13:58)
2F:推 nikeasyanzi:那我一把ptr 指到别的地方 也回不去原本的test了XD 10/20 00:59
3F:→ scwg:楼上这也不一定, 有的 compiler 会让档案里每次用 "test" 都 10/20 01:10
4F:→ scwg:对应到同个 _test, 所以 ptr = "test" 有可能指回原本的test 10/20 01:10
5F:→ EdisonX:嗯,後面这里主要还是要看 compiler 能力。 10/20 16:05