作者blexx (布雷克斯)
看板C_and_CPP
標題Re: [問題] 找記憶體位置
時間Sun Nov 29 12:16:11 2009
※ 引述《devilarise (Devil)》之銘言:
: 本文回給VictorTom:因為想說的頗多, 所以就不洗推文了
: 首先, 謝謝你的指教@@
: 1.
: :我覺得您自己先把pointer和address給分清楚再說
: 請問你認為是哪邊不夠清楚呢?
你要不要把這段翻成英文,然後你就知道自己錯在哪:「而第二行和第三行的意思是說宣
告一個字元指標, 並將這個指標用來存放str陣列[0]的指標(即指標的指標)」
char *x 就是一個 char 變數位址的指標。
char **x 才是一個 char 變數位址的指標變數的指標。
以字串為例,
char x[]="abcde";
如果你取 x,拿到的是 'a' 的位址;如果取 x[0],拿到的就是 'a'。
所以,
char *q = &x[0];
是把 x[0] 這個 char variable 的 address 賦值到 q 這個 char pointer 裡。
會把 char *q = &x[0] 說成「指標的指標」的人,我不覺得他真的懂指標是啥。
: 3.
: :還有, 個人覺得你C++的傳址的觀念有問題
: 恩, 我大概描述一下我的觀念, 請你再指教一下好嗎?@@
: 以一個
: int a = 10;
: 這樣的宣告來說
: 我認為是宣告了一塊記憶體位址, 存放了10這個值
: 比較具像的表示是
: 變數名稱a
: 變數內容10
: 變數位址0x123456
: 大致上是這樣的
: 而我若宣告了一個int b;
: 然後寫上 b = a;
: 這是為一種傳遞"值"的拷貝動作
: 電腦會將a的值, 複製一份給b
: 而如果寫成 int* b = &a;的話
: 視為一種傳址的動作
: 從此a跟b兩個變數的記憶體位址
: 同時指向0x123456這個位置上
: 因此, 無論改變哪個變數
: 另一個都會同步改變, 因為他們都是同一個記憶體位置
: 4.
: :嚴格來說, char *s=&str[0]; 是一個傳值的動作, 它是把str[0]的address傳值到s去
;
: 在這裡我看見的是指標的傳遞說@@ 請問哪本書教你
: pointer variable = &variable;
: 這樣的寫法是傳值而非傳指標呢?@@
: 我想去拜讀一下
: 我能猜到你大概是這樣想的
: 這裡我們都明白, char* s; 宣告了一個空指標,
: 沒內容, 隨機在記憶體內取一個沒用到的空間,
: 所以把&str[0];的記憶體位址填寫進這個指標內
: 而如果你認為的傳值傳址議題
: 不是在討論, 傳遞指標, 還是傳遞內容值的話
: 那只能說我們都沒啥錯, 只是因為在受教育的時候
: 我就根深蒂固的學習了老師那派的看法
: 只要是傳遞指標, 就是看成一種傳址
比較奇怪的是你。
在 C 裡面只有 pass by value 的機制,所謂的 pass by address 只是傳了一個可以用
來當作位址的值。
fn(x) 跟 fn(&x) 兩者都是將一個數值傳入。差別在於前者傳入 x 變數的值,後者傳入
x 變數的位址。但是對函數本身,那都是一個 value。你高興存成什麼型都可以,爽的
話還可以把一個記憶體位址的值存成四個 char 印出來。(只是一點意義都沒有)
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 124.9.132.233
→ devilarise:恩 以後發文之前我會先練習把中文翻成英文低! 11/29 12:31
→ tinlans:這老問題了,先用 typedef 把星星藏起來,再用 macro 把 11/29 12:39
→ tinlans:& 這個強制取 lvalue 的 operator 包裝一下,就能呈現出完 11/29 12:39
→ tinlans:全長得像 pass-by-value 的 code XD 11/29 12:39
→ tinlans:簡單說就是太多人被 * 跟 & 給迷惑住了。 11/29 12:40