• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            山寨:不是最好的,是最適合我們的!歡迎體驗山寨 中文版MSDN

            Blog @ Blog

            當(dāng)華美的葉片落盡,生命的脈絡(luò)才歷歷可見。 -- 聶魯達(dá)

            常用鏈接

            統(tǒng)計

            積分與排名

            BBS

            Blog

            Web

            最新評論

            [轉(zhuǎn)]深入C++指針

            本篇是第一篇,介紹指針的本質(zhì)是什么。

            在相當(dāng)一部分的C++教程中,講到指針時,基本上都會舉swap(int a,int b)這個 數(shù)據(jù)交換的例子。我也同樣愿意舉這個例子作為講述指針的開始。

            下面是類的代碼內(nèi)容:

            //……限于篇幅,只留說明問題的部分內(nèi)容……

            定義部分:

            public:

                       
            void swap(int a,int b);

            實現(xiàn)部分:

            void CPointerResearch::swap(int x,int y){

                       
            int nTmp = x;

                       x 
            = y;

                       y 
            = nTmp;

            }

            下面是測試數(shù)據(jù)及結(jié)果:

            輸入:

            100, 200

            輸出(執(zhí)行swap函數(shù)后):

            100, 200

            Press any key to continue

             

            可以很清楚的看出,并沒有實現(xiàn)數(shù)據(jù)交換。

            我們來假想一下程序員寫這樣程序時的心里:有兩個小框,甲框放數(shù)字為100的卡片,乙框放數(shù)字為200的卡片,現(xiàn)將兩張卡片交換一下位置,變成甲框存放數(shù)字為200的卡片,乙框存放數(shù)字為100的卡片。

            這樣的想法有問題嗎?答案很明確,一點點問題都沒有!想法完全正確,他(她)只要確實是這樣做的,卡片交換就一定能成功。但為什么上面的程序模擬這樣的執(zhí)行過程,結(jié)果卻不是想要的呢?要想徹底弄明白這個問題,我們必須認(rèn)識問題的根本,即這個問題的本質(zhì)是什么,這才是真正解決問題。

            我們來深入分析一下上面那個看似簡單的假想情景。第一,有兩個框,這是確定的事實,毋庸置疑。第二,框里都裝有卡片,并且上面的數(shù)字不同,這個是不爭的事實。第三,交換卡片過程中,雖然兩個框都沒挪動,但里面的卡片都有挪動。第四,卡片挪動是從一個框挪到另一個框。正是有了這四點作保證,卡片才得以成功交換。換句話說,上面的數(shù)據(jù)交換程序的執(zhí)行交換過程如果滿足這四個條件的話,計算機執(zhí)行后輸出的結(jié)果就一定是我們期待的正確結(jié)果。那么,至此出錯原因已很明確,就是計算機執(zhí)行程序的過程中,上面這四點至少有一點一定不符合。下面一一分析。

            第一, 從輸入條件看。

            輸入條件是int a =100;int b= 200;從這兩個C++語句我們可以看出,兩個“框”已經(jīng)有了,分別是ab,也就是說具備了第一個條件。此外,甲框(a)放了數(shù)字為100的卡片(int a=100;, 乙框(b)放了數(shù)字為200的卡片(int b=200;),這說明第二個條件也具備。從輸入條件已經(jīng)看不出什么其它的有用的信息。至此我們已經(jīng)可以判斷出問題出在后兩個條件有不滿足的地方。

            第二, swap函數(shù)體看。

            函數(shù)體         int nTmp = x;              x = y;                 x = nTmp;是最典型的只用三行代碼就實現(xiàn)數(shù)據(jù)交換的代碼。沒問題,在執(zhí)行這三行代碼前和執(zhí)行后分別打印輸出就可以看得一清二楚,確實實現(xiàn)交換了。這說明上面的第四個條件也滿足,因為這三行代碼就是“從甲框拿x卡片放到地上,再把乙框的y卡片放入甲框,最好將地上的那張卡片(就是x卡片)揀起來放到乙框中去”。那么,到現(xiàn)在可以說明問題出在第三個條件不滿足。我們再繼續(xù)分析下去。

            第三, swap函數(shù)聲明看。

            從數(shù)據(jù)交換的程序代碼看,也就只剩這么一點東西還沒有去分析一下。我們的執(zhí)行過程其實又有幾個分步驟:

            首先,輸入:int a= 100; int b= 200;這只是賦值操作,肯定沒有問題。

            其次,執(zhí)行:步驟1,為調(diào)swap(int x,int y)函數(shù)做準(zhǔn)備,將a傳給xb傳給y。

                       步驟2,執(zhí)行swap(x, y),就是執(zhí)行函數(shù)體內(nèi)容。步驟2在上面已經(jīng)得到驗證,沒問題。

            最后,執(zhí)行完畢在主函數(shù)里輸出ab100,200,這是調(diào)C++標(biāo)準(zhǔn)輸出函數(shù)輸出的,提供什么數(shù)據(jù)就如實地輸出來。這也沒問題。

            至此,問題已經(jīng)可以定位,就在“其次”里的“步驟1”!對這一步的執(zhí)行過程再繼續(xù)細(xì)分,就是:將甲框(輸入的a)的數(shù)字為100的卡片放到丙框(swap函數(shù)的參數(shù)x1, 將乙框(b)的數(shù)字為200的卡片放到丁框(swap函數(shù)的參數(shù)y)。程序接下來就是執(zhí)行“其次”里的“步驟2”,也即進(jìn)入函數(shù)體執(zhí)行,這時候在悄悄的把丙框和丁框的卡片相交換??梢娫瓉斫粨Q的是丙框和丁框!甲框和乙框原來是什么樣還是什么樣。這當(dāng)然不會看到期望的輸出。

            所以解決問題的根本是必須要“找對框”,只交換想要交換的“框”。對這個“找對框”的真正理解程度會直接反映出對指針的真正理解程度。 這樣,可能的解決方法比如:

            基于指針swap方法(直接拿甲框和乙框的卡片并進(jìn)行交換,根本就沒有丙框和丁框):

            void CPointerResearch::swap(int* x,int* y){

                       
            int nTmp = *x;

                       
            *= *y;

                       
            *= nTmp;

            }

            基于引用swap方法(不直接用丙框(而是引用到甲框)和丁框(而是引用到乙框)):

            void CPointerResearch:: swap (int& x,int& y){

                       
            int nTmp = x;

                       x 
            = y;

                       y 
            = nTmp;

            }

            1本文舉的假想例子主要是為了說明問題,但例子不一定很貼切。“將甲框(輸入的a)的數(shù)字為100的卡片放到丙框(swap函數(shù)的參數(shù)x)”這句話,更貼切的說應(yīng)該是“甲框有跟線系在數(shù)字為100的卡片上,現(xiàn)在執(zhí)行“a傳給x”操作,就是說丙框要拉一根線出來也系到那張數(shù)字為100的卡片上”。

             

            本篇內(nèi)容強調(diào)的就是一點,“什么是指針?指針的本質(zhì)是什么?”。理解指針的本質(zhì)是學(xué)習(xí)指針的關(guān)鍵所在。特別是初學(xué)指針者,如果能把這個swap函數(shù)真正搞明白,那么對指針的理解應(yīng)該說已經(jīng)有了一定的功底。如果很浮躁或很膚淺的去看待指針,是不會真正掌握指針的豐富內(nèi)涵的。用指針,要用,那就要用到“沒指針,就感覺不知道如何是好”這個地步。否則用指針也沒太大的意思,又容易出錯,不止怎么排除,自己可能興趣也不高。

            posted on 2007-08-12 23:53 isabc 閱讀(369) 評論(0)  編輯 收藏 引用 所屬分類: C++基礎(chǔ)

            廣告信息(免費廣告聯(lián)系)

            中文版MSDN:
            歡迎體驗

            一本一本久久A久久综合精品| 久久免费高清视频| 久久久久久噜噜精品免费直播| 国产成人综合久久久久久| 久久成人18免费网站| 亚洲欧美久久久久9999| 久久精品国产免费观看三人同眠| 亚洲第一极品精品无码久久| 麻豆亚洲AV永久无码精品久久| 精品综合久久久久久888蜜芽| 99久久精品免费看国产| 中文精品99久久国产| 久久夜色精品国产欧美乱| 欧美激情精品久久久久| 久久久久人妻一区二区三区| 久久精品亚洲日本波多野结衣| 久久不见久久见免费影院www日本| 亚洲精品无码久久久久去q | 久久久久久国产a免费观看不卡 | 老男人久久青草av高清| 国产成人精品白浆久久69| 久久影院亚洲一区| 久久久久久a亚洲欧洲aⅴ| 久久精品极品盛宴观看| 国产午夜精品理论片久久| 亚洲色大成网站www久久九 | 久久男人Av资源网站无码软件| 国内精品久久久久久久涩爱| 久久久久99精品成人片欧美 | 久久久久久久久无码精品亚洲日韩| 久久青草国产手机看片福利盒子 | 国产99久久久国产精免费| 久久亚洲精品无码AV红樱桃| 久久性生大片免费观看性| 久久综合狠狠综合久久激情 | 国产精品欧美亚洲韩国日本久久| 熟妇人妻久久中文字幕| 久久狠狠爱亚洲综合影院| 欧美一级久久久久久久大片| 亚洲国产精品婷婷久久| 99国产精品久久|