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

            printf都做了什么??

            最近在看以前的一些代碼,發現程序中有一些函數返回指針,而且所返回的指針是stack指針,覺得很是奇怪,stack指針都是系統自己維護,出了作用域以后自動釋放的,難道函數所返回的stack指針還能繼續使用?以前的代碼就是那樣,而且運行也一直很正常,這是什么原因?覺得很是怪異。
            為測試stack指針是否由系統管理,從函數中返回后是否繼續可用,寫了一些代碼:
            // TestPointer.cpp : Defines the entry point for the console application.
            //
            #include "stdafx.h"
            #include 
            <windows.h>
            #include 
            <stdlib.h>

            typedef 
            struct Person
            {
                
            int iAge;
                
            int iWeight;
            }
            Person;

            //Printf都做了什么?
            //感覺調用printf時系統對stack進行了清理
            char * GetString(void);
            Person 
            * GetPerson();

            int main(int argc, char* argv[])
            {
                printf(
            "Hello World!\n");

                
            char * pStr = GetString();

                
            //感覺調用printf時系統對stack進行了清理
                printf("%s", pStr); //將這一句去掉后運行試試?

                Person 
            * m_pPersion = GetPerson();
                
                printf(
            "doooooo\n"); //將這一句去掉運行試試?
                printf("Age = %d, Weight = %d\n", m_pPersion->iAge, m_pPersion->iWeight);

                
            return 0;
            }


            char * GetString(void)
            {
                
            //簡單的可以理解為: 
                
            //heap:是由malloc之類函數分配的空間所在地。地址是由低向高增長的。 
                
            //stack:是自動分配變量,以及函數調用的時候所使用的一些空間。地址是由高向低減少的。
                
            //棧(stack)內存的情況
                char szMessage[100];
                strcpy(szMessage, 
            "this is just a test!\n");
                printf(
            "%s", szMessage);
                
            return szMessage;

                
            //堆(heap)內存的情況
                /*char * pRet = (char *)malloc( 100 * sizeof(char));
                strcpy(pRet, "This is just a test!\n");
                return pRet;
            */
                
            }


            Person 
            * GetPerson()
            {
                
            //stack
                Person m_Person;
                m_Person.iAge 
            = 24;
                m_Person.iWeight 
            = 55;

                
            return &m_Person;

                
            //更換成heap形式的又是怎樣?
            }


            上述程序運行環境為:WindowsXP sp2 
            + Visual C++ Enterprise Edition 6.0 + Vs6Sp6
            源代碼

            posted on 2008-04-18 20:32 猶志 閱讀(1742) 評論(5)  編輯 收藏 引用

            評論

            # re: printf都做了什么??[未登錄] 2008-04-18 21:16 steven

            昏。在棧上的數據嘛,肯定沒有問題了。  回復  更多評論   

            # re: printf都做了什么?? 2008-04-18 22:52 lonkil

            你到Release下看看.再用GCC編譯一下試試.

            我試了這幾種情況運行結果都不一樣.

            說明這種用法存在問題,與printf無關.

            應該heap或在調用函數里把空間分配好,傳給子函數賦值.  回復  更多評論   

            # re: printf都做了什么?? 2008-04-19 01:01 嘯天豬

            所謂stack自動清理的意思是:函數調用前后調整棧指針(SP)的任務編譯器會自動幫你完成

            至于指向棧中位置的指針,當然可以隨便用,不過這和把指針指向內存位置0一樣,后果自負

            程序的運行結果無法證明程序的正確性  回復  更多評論   

            # re: printf都做了什么?? 2008-04-19 22:03 starofrainnight

            這是初學者很容易犯錯誤,想當年我初學C++時也是對這個問題覺得很奇怪。

            首先,把棧指針傳遞出來是原則性錯誤,在C++裡是不允許的,而在函數結束後讀取該指針指向的內容的行為是未知的。
            其次,棧內存是在函數開始執行時進行分配,在函數結束進行釋放的。
            再次,棧內容在函數結束是不會被清理的,因為釋放了的內存不需要再去清理。

            但正因為沒有進行清理,在調用此函數後,你馬上讀取該內存,在大部分情況下是可以讀取到原來的內容的,只要沒有其它的程序使用到該塊內存,那些內容是不會改變的,但這種操作是錯誤的,因為該塊內存已經被釋放了,你所讀取的是已經被釋放了的內存的內容。

            根據各種編譯器的編譯結果不同,根據系統需要不同,根據你程序編寫的不同,你這個函數所產生的結果是不可預料的,如上,後果自負。  回復  更多評論   

            # re: printf都做了什么??[未登錄] 2008-05-01 18:51 lynn

            starofrainnight說的很對;正如樓主所述,stack使用是由高向低進行的。而您代碼中描述的:
            char szMessage[100];
            strcpy(szMessage, "this is just a test!\n");
            數組Message是如此之大,而使用卻如此之小,僅"this is just a test!\n"幾個字符。這樣,存儲szMessage時從低址向高址進行,100-22=78個字節尚未使用,退出GetString函數之后。sp指針復原至調用GetString之前的位置。而調用GetPerson的活動記錄太小,以至于沒有破壞szMessage中存儲的22個字符。所以,...
              回復  更多評論   

            導航

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            統計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            文章檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久人妻少妇嫩草AV无码专区| 潮喷大喷水系列无码久久精品| 久久中文精品无码中文字幕| 亚洲精品97久久中文字幕无码| 伊人久久综合无码成人网| 久久人人爽人人爽人人片AV麻豆| 国产精品99久久久久久猫咪 | 久久无码AV中文出轨人妻| 久久久久亚洲AV无码观看| 久久99国产亚洲高清观看首页| 久久伊人五月天论坛| 国产精品久久久久影院嫩草| 久久人与动人物a级毛片| 亚洲国产精品婷婷久久| 一本色道久久99一综合| 久久久久国产日韩精品网站| 久久国产高潮流白浆免费观看| 久久久WWW成人| 久久青青草原国产精品免费| 国产精品久久久久蜜芽| 久久久久亚洲爆乳少妇无| 久久99国产亚洲高清观看首页| 综合人妻久久一区二区精品| 日韩精品久久久久久久电影| 久久精品国产一区二区电影| 草草久久久无码国产专区| 看久久久久久a级毛片| 久久人人爽人人爽人人片AV不| 久久久噜噜噜久久中文字幕色伊伊 | 亚洲熟妇无码另类久久久| 深夜久久AAAAA级毛片免费看| 99热成人精品免费久久| 国产精品热久久无码av| 久久久久香蕉视频| 久久99久久成人免费播放| 国产亚洲色婷婷久久99精品91| 亚洲国产精品久久久久婷婷老年 | 精品国产乱码久久久久久呢| 奇米影视7777久久精品人人爽| 久久午夜免费视频| 精品人妻伦九区久久AAA片69|