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

            love in C++, live on MFC

            to get ready...

            C++博客 首頁 新隨筆 聯系 聚合 管理
              47 Posts :: 0 Stories :: 97 Comments :: 0 Trackbacks
            在《工作中發現的 》中,提到析構函數可以自己調用,并用一個例子編譯、運行證明了。
            現在有個問題,除了知道“析構函數可以自己調用”外,那么什么時候必須顯式調用析構函數?

            先看一段現實生活中的代碼吧,mfc源碼中:
            BOOL CStatusBar::AllocElements(int nElements, int cbElement)
            {
                
            // destruct old elements
                AFX_STATUSPANE* pSBP = _GetPanePtr(0);
                
            for (int i = 0; i < m_nCount; i++)
                {
                    pSBP
            ->strText.~CString();   //注意看這里
                    
            ++pSBP;
                }

                
            // allocate new elements
                if (!CControlBar::AllocElements(nElements, cbElement))
                    
            return FALSE;

                
            // construct new elements
                pSBP = _GetPanePtr(0);
                
            for (i = 0; i < m_nCount; i++)
                {
                    memcpy(
            &pSBP->strText, &afxEmptyString, sizeof(CString));
                    
            ++pSBP;
                }
                
            return TRUE;
            }
            在上面的代碼中,就有顯式調用CString的析構函數的代碼。cool。
            因為還調用了CControlBar::AllocElements(),上面的代碼不是很明顯,我把CControlBar::AllocElements簡化一下后:
            BOOL CStatusBar::AllocElements(int nElements, int cbElement)
            {
                
            // destruct old elements
                AFX_STATUSPANE* pSBP = _GetPanePtr(0);
                
            for (int i = 0; i < m_nCount; i++)
                {
                    pSBP
            ->strText.~CString();   //注意看這里
                    ++pSBP;
                }

                
            // allocate new elements
                
            //if (!CControlBar::AllocElements(nElements, cbElement))
                
            //    return FALSE;
                
            //簡化后的代碼,實際運行肯定有問題,但是關鍵東西出來了
                free(pSBP);//注意這里調用的是free
                pSBP = calloc(nElements, cbElement);

                
            // construct new elements
                pSBP = _GetPanePtr(0); //根據mfc的代碼,可以理解這里的pSBP和前面的pSBP還是同一個地址
                for (i = 0; i < m_nCount; i++)
                {
                    memcpy(
            &pSBP->strText, &afxEmptyString, sizeof(CString));
                    
            ++pSBP;
                }
                
            return TRUE;
            }
            這個時候,如果注意到我特別注釋的free函數調用,可能已經意識到了為什么要顯式調用析構函數了。
            如果還沒有,那么可以問自己一個面試常規問題:delete和free有什么區別?答:delete會使析構函數被調用。
            或者反過來說,free沒有調用析構函數,那么怎么辦?所以你必須自己顯示調用析構函數。

            上面的這個例子可以這樣抽象下,現在需要free掉一塊內存,而那塊內存中,還有一個類,類里面還有指針,(這里是CString)需要在析構函數中釋放內存。因為用的是free,所以那個類的析構函數不會自動被調用,這個時候,就必須顯式調用那個類的析構函數。

            這個是不是很偏的問題呢?遇到了就看看,沒有遇到過,也不會影響日常工作,哈。

            另外繼續問個面試問題,new和calloc的區別?哈,構造的函數的調用啊
            所以,上面的代碼用的calloc,就必須顯示調用構造函數啊,在哪里呢?就是
            memcpy(&pSBP->strText, &afxEmptyString, sizeof(CString));
            和CString的構造函數比較下:
            _AFX_INLINE CString::CString()
                { m_pchData 
            = afxEmptyString.m_pchData; }
            但是,為什么不就直接調用構造函數呢?我也不知道。詳見dhong下面的評論。(dhong糾正了我的一個錯誤)

            不過,下面的代碼
                    CString aStr;
                    CString
            * pStr = &aStr ;
                    pStr
            ->CString();

            是編譯不過的。

             

            posted on 2006-03-04 00:35 flyingxu 閱讀(11635) 評論(7)  編輯 收藏 引用 所屬分類: C/C++

            Feedback

            # re: 什么時候必須顯式調用析構函數? 2006-03-04 01:37 dhong
            構造函數顯式調用:
            new (pStr) CString();

            您需要直接學c++,而不是從mfc學c++  回復  更多評論
              

            # 為什么不就直接調用構造函數呢? 2006-03-04 10:18 力為
            placement new/delete:
            EC++和MEC++有詳細的解釋。

            --------------------------------------------
            delete和free有什么區別?什么時候必須顯式調用析構函數?
            還得從對象的構造說起。對象的構造方式決定了它的析構方式。
            C++提供了自定義new和delete的機制,程序員可以自己實現內存的分配釋放策略。
            具體還是看看EC++和MEC++

              回復  更多評論
              

            # re: 什么時候必須顯式調用析構函數? 2006-03-04 14:01 笑笑生
            呵呵,挺好的,還是不要自己調用析構  回復  更多評論
              

            # re: 什么時候必須顯式調用析構函數? 2006-03-13 17:34 沐楓網志
            樓主其實如果能夠再加以說明,為什么需要調用析構函數,以及在什么情況下應該調用析構函數,這樣就太好了。

            而這篇隨筆里頭,只看到因調用析構函數而帶來的快感--cool.  回復  更多評論
              

            # re: 什么時候必須顯式調用析構函數? 2006-03-16 17:12 stone
            建議:萬不得已時才使用“placement new”語法。只有當你真的在意對象在內存中的特定位置時才使用它。例如,你的硬件有一個內存映象的 I/O計時器設備,并且你想放置一個Clock對象在那個內存位置。

            危險:你要獨自承擔這樣的責任,傳遞給“placement new”操作符的指針所指向的內存區域必須足夠大,并且可能需要為所創建的對象進行邊界調整。編譯器和運行時系統都不會進行任何的嘗試來檢查你做的是否正確。
              回復  更多評論
              

            # re: 什么時候必須顯式調用析構函數? 2006-03-16 17:14 flyingxu
            @沐楓網志
            簡單的說吧:

            為什么需要調用析構函數?
            當然是為了讓該對象做釋放資源的善后工作

            以及在什么情況下應該調用析構函數?
            想讓對象釋放它運行中分配的內存,但是對象本身的內存不釋放(比如對象中還還有指向另一塊內存的指針時的情況),或者不能用delete釋放,比如例子中時用calloc分配的內存是不能用delete釋放的  回復  更多評論
              

            # re: 什么時候必須顯式調用析構函數?[未登錄] 2015-04-07 20:31 111
            @dhong
            可以調用pStr->CString::CString();  回復  更多評論
              

            精品久久久久久国产三级| 思思久久精品在热线热| 久久99热精品| 久久人人超碰精品CAOPOREN| 亚洲精品99久久久久中文字幕| 精品久久久中文字幕人妻 | 久久综合久久综合久久| 国产成人AV综合久久| 久久久久久久97| 亚洲综合久久综合激情久久| 无夜精品久久久久久| 亚洲国产另类久久久精品| 久久99热国产这有精品| 亚洲Av无码国产情品久久| 东京热TOKYO综合久久精品 | 久久SE精品一区二区| 91精品国产综合久久香蕉| 中文字幕无码免费久久| 国产亚州精品女人久久久久久 | 亚洲七七久久精品中文国产 | 久久香蕉国产线看观看99| 日本亚洲色大成网站WWW久久| 国产精品9999久久久久| 伊人 久久 精品| 久久国产免费直播| 国产亚洲欧美成人久久片| 久久精品卫校国产小美女| 久久精品国产亚洲AV不卡| 久久精品视频网| 久久99精品国产自在现线小黄鸭| 亚洲精品NV久久久久久久久久| 成人精品一区二区久久| 99热都是精品久久久久久| 精品久久久久久综合日本| 久久精品国产99久久久| 性欧美丰满熟妇XXXX性久久久| 欧美亚洲国产精品久久| 综合久久精品色| 亚洲精品美女久久久久99| 无码人妻少妇久久中文字幕蜜桃| 久久狠狠爱亚洲综合影院|