• <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>

            hellohuan

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              2 Posts :: 3 Stories :: 0 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            程序如下:
            #include <iostream>
            using namespace std;


            void fuck(int *&j)
            {
            int l = 20;
            int *k = &l;
            j = k;
            k = 0;
            }

            void any_function_use_local_variables()
            {
            int a, b, c;
            a=b=c=100;
            }

            int main()
            {

            int i = 10;
            int *j = &i;

            fuck(j);
            /////-------------------------
            cout < <*j < <endl;   
            ////-------------------------
            cout < <*j < <endl;

            any_function_use_local_variables();
            ////-------------------------
            cout < <*j < <endl;
            //
            cout < <*j < <endl;

            return 0;
            };


            打印結果,四次cout < <*j < <endl;結果都不同,依次是:
            20
            274148040
            -858993460
            274148040
            這個我開始就不太明白了,明明fuck了局部變量為什么還能得到20的值,j應當指向一塊不確定的內存區域,卻有了幾次不一樣的結果。
            于是在論壇里面貼了出來,自己也查了很多資料試驗了很多程序。
            原因我的理解基本是這樣:
            第一個輸出時因為是剛剛返回 ,雖然局部變量銷毀了.
            (我的理解銷毀:就是我放棄了這個地方了.原來我在那放了一個蘋果,在沒人用這塊地方時蘋果還在)
            所以第一個輸出還是20。之后這塊內存應該被用過了,所以變成了其它的值。
            下面是一位牛人的回復,挺有道理!
            ///////////////////
            第一次輸出:在void fuck(int *&j) 函數中,聲明的局部變量K,假設地址為oxff71,在函數中,這個地址賦值給了j;
            然后,函數中的局部變量K所指的內存的值為20;然后,fuck函數結束,局部變量的內存被釋放,單這個釋放只是說明了這塊內存可以被重新使用,并不是把內存里的數值歸0了,所以。在第一次輸出的時候,*j為20;

            第2次輸出:其實cout < <也是調用了一個函數,這個函數怎么實現我并不知道,但是有理由相信,在這個函數中是要使用一些局部變量的,那么當第一次輸出了*j以后,這個函數或許沒有結束,它里面的局部變量使用了剛剛fuck釋放的那塊內存,然而又有局部變量使用了oxff71這個地址,但是變量J所指的地址也正好是這樣,所以,輸出了另一組數字。

            第3次輸出:在調用了any_function_use_local_variables()這個函數后,其實我們可以把any_function_use_local_variables 這個函數簡化下, 簡化成下面這樣
            void any_function_use_local_variables()
            {
            int a=10;
            int b =100;
            }
            通過代碼跟蹤調試可以知道,any_function_use_local_variables函數還是使用了fuck釋放的內存,因為我們可以清楚的看到 b的地址是oxff71,所以第3次輸出的就是100了。

            其實我們可以在3個cout < <*j < <endl以后在加一個 cout < <*j < <endl,可以看到第4個輸出和第2個輸出是一樣的,從而就證明了我對第2次輸出的猜想。


            posted on 2008-07-29 21:08 炮灰九段 閱讀(72) 評論(0)  編輯 收藏 引用
            伊人伊成久久人综合网777| 久久精品日日躁夜夜躁欧美| 久久九九久精品国产| 久久精品国产72国产精福利| 国产精品久久久久一区二区三区 | 97热久久免费频精品99| 婷婷久久综合九色综合98| 亚洲成色WWW久久网站| 狠狠色丁香久久综合婷婷| 香港aa三级久久三级| 国产精品熟女福利久久AV| 色偷偷88欧美精品久久久| 久久久噜噜噜www成人网| 亚洲国产精品久久久久久| 久久亚洲色一区二区三区| 99久久国产综合精品五月天喷水| 久久国产综合精品五月天| 亚洲中文字幕久久精品无码APP| 久久无码人妻精品一区二区三区| 国产毛片欧美毛片久久久 | 亚洲国产天堂久久久久久| 日韩亚洲欧美久久久www综合网| 精品久久久久久国产潘金莲 | 国产激情久久久久影院老熟女免费| 人妻少妇精品久久| 久久青草国产精品一区| 亚洲AV日韩精品久久久久久 | 国产综合免费精品久久久| 国产精品久久国产精麻豆99网站 | 老司机午夜网站国内精品久久久久久久久| 香蕉久久夜色精品国产2020| 99久久99这里只有免费的精品| 一级女性全黄久久生活片免费 | 久久中文娱乐网| 一级做a爰片久久毛片毛片| 久久国产精品免费| 99久久国产亚洲高清观看2024 | 亚洲а∨天堂久久精品9966| Xx性欧美肥妇精品久久久久久| 久久99精品国产一区二区三区| 精品久久777|