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

            eryar

            PipeCAD - Plant Piping Design Software.
            RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
            posts - 603, comments - 590, trackbacks - 0, articles - 0

            Memory Management in C++

            Posted on 2013-01-09 20:57 eryar 閱讀(3071) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

            Memory Management

            Use the same form in corresponding uses of new and delete

            eryar@163.com

            對應的newdelete要采用相同的形式

            new operator時會發(fā)生兩件事:首先,內存通過operator new被分配;然后,為被分配的內存調用一個或多個構造函數。

            delete operator時也會發(fā)生兩件事:首先,為將釋放的內存調用一個或多個析構函數;然后,通過operator delete釋放內存。

            對于delete operator來說會有這樣一個重要的問題:內存中有多少個對象需要被刪除呢?刪除多了,程序也就崩潰了;刪除少了,就有內存未被正確釋放。這個問題簡單來說就是:要被刪除的指針指向是單個對象,還是對象數組?這只有你來告訴delete operator。如果你在用delete operator時沒有括號,delete就會認為指向的是單個對象;否則它就會認為指向的是一個數組。

            Prefer new and delete to malloc and free

            mallocfree(及其變體)會產生問題的原因在于它們太簡單:他們不知道構造函數和析構函數。(有時越簡單越好。)

            假設用兩種方法給一個包含10string對象的數組分配空間,一個用malloc,另一個用new

            其結果是,stringarray1確實指向的是可以容納10string對象的足夠空間,但內存里并沒有創(chuàng)建這些對象。當釋放這些內存時,你一定會這么做:

            調用free將會釋放stringarray1指向的內存,但內存里的string對象不會調用析構函數。如果string對象象一般情況那樣,自己已經分配了內存,那這些內存將會全部丟失。相反,當對stringarray2使用delete時,數組里的每個string對象都會在內存釋放前調用析構函數。即然newdelete可以這么有效地與構造函數和析構函數交互,選用它們是顯然的。

            new/deletemalloc/free混用也是個壞想法。對一個用new獲取來的指針調用free,或者對一個用malloc獲取來的指針調用delete,其后果是不可預測的。

            示例程序:

              1: 
            
              2: #include <iostream>
            
              3: using namespace std;
            
              4: 
            
              5: class CTest
            
              6: {
            
              7: public:
            
              8:     CTest() { cout<<"Default constructor."<<endl; }
            
              9:     ~CTest() { cout<<"Default destrcutor."<<endl; }
            
             10: 
            
             11: };
            
             12: 
            
             13: int main(int argc, char *argv[])
            
             14: {
            
             15:     cout<<"=== Test new/delete begin ==="<<endl;
            
             16:     CTest* pTestNewDelete = new CTest;
            
             17:     delete pTestNewDelete;
            
             18:     cout<<"=== Test new/delete end   ==="<<endl;
            
             19: 
            
             20:     cout<<"~~~ Test malloc/free begin ~~~"<<endl;
            
             21:     CTest* pTestMallocFree = static_cast<CTest*> (malloc(sizeof(CTest)));
            
             22:     free(pTestMallocFree);
            
             23:     cout<<"~~~ Test malloc/free end   ~~~"<<endl;
            
             24:     
            
             25:     return 0;
            
             26: }
            
             27: 

            輸出:

            1 === Test new/delete begin ===
            2 Default constructor.
            3 Default destrcutor.
            4 === Test new/delete end   ===
            5 ~~~ Test malloc/free begin ~~~
            6 ~~~ Test malloc/free end   ~~~
            7 

            來源:

            1. Scott Meyers Effective C++

             

            亚洲午夜久久久影院伊人| 99久久国产亚洲高清观看2024| 久久精品国产99国产精品澳门| 97久久精品国产精品青草| 久久综合日本熟妇| 久久综合香蕉国产蜜臀AV| 99久久精品国产一区二区三区 | 99久久无码一区人妻| 人妻系列无码专区久久五月天| www.久久精品| 亚洲精品久久久www| 国产真实乱对白精彩久久| 影音先锋女人AV鲁色资源网久久 | 亚洲精品国精品久久99热| 午夜精品久久久久久中宇| 一级做a爰片久久毛片看看 | 久久精品成人免费观看97| 国产精品久久久久久一区二区三区 | 综合久久国产九一剧情麻豆| 久久99免费视频| 亚洲精品乱码久久久久久久久久久久| 亚洲狠狠久久综合一区77777| 亚洲综合熟女久久久30p| 久久无码一区二区三区少妇 | 亚洲日本久久久午夜精品| 久久99精品国产麻豆婷婷| www性久久久com| 国内精品久久久久久野外| 亚洲综合日韩久久成人AV| 久久妇女高潮几次MBA| 伊人久久无码中文字幕| 精品久久久久久无码不卡| 久久SE精品一区二区| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 中文国产成人精品久久亚洲精品AⅤ无码精品 | 伊人久久大香线蕉影院95| 国产精品一久久香蕉国产线看| 久久久久亚洲精品无码蜜桃 | 一本一道久久精品综合| 中文精品久久久久国产网址| 亚洲综合久久综合激情久久|