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

            公告

            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            統(tǒng)計

            • 隨筆 - 9
            • 文章 - 13
            • 評論 - 3
            • 引用 - 0

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            在預先定義的內(nèi)存位置構(gòu)造一個對象

            在預先定義的內(nèi)存位置構(gòu)造一個對象

            趙湘寧

            ??? 常常有人問這樣一個C++問題:如何在預先定義的內(nèi)存位置構(gòu)造一個對象?在預先定義的內(nèi)存緩沖構(gòu)造一個對象有許多有用的應用。例如,一個定制的垃圾搜集器能使用一個大的預分配內(nèi)存緩沖,用戶在這個緩沖中構(gòu)造其對象。當不再需要這些對象時,它們的存儲空間被自動收回。
            ?? 這個技術在重視時間的應用中也很有用。在預先分配的內(nèi)存緩沖構(gòu)造一個對象是一種“時間常量”操作,之所以這樣說是因為程序分配操作本身不會浪費寶貴的時間。同時也要注意當系統(tǒng)沒有足夠的內(nèi)存時,動態(tài)內(nèi)存分配可能失敗。因此,對于重視任務的應用,預先分配一個足夠大的緩沖有時是不可避免的。
            ??? 許多應用需要在給定的時間構(gòu)造不同類型的對象。想一想這樣一個例子,一個GUI應用根據(jù)用戶的輸入,每次、顯示不同的對話框,利用重復分配和釋放內(nèi)存,這個應用能提前創(chuàng)建一個內(nèi)存緩沖,并能在這個緩沖里反復構(gòu)造和銷毀不同類型的對象。
            ??? C++提供了幾種特點來方便實現(xiàn)在預先決定的內(nèi)存位置構(gòu)造一個對象的任務。在這些特點中,包括一個特殊形式的new操作符,叫做“定位new”(placement new)操作,以及一個顯式的析構(gòu)處理。實現(xiàn)方法如下:
            ??? 第一步:分配一個足夠的內(nèi)存緩沖區(qū),以便存放給定類型的對象。如果想要每次構(gòu)造不同類型的對象,需要至少以最大的對象所占空間的大小分配一個緩沖。預分配的緩沖是在可用內(nèi)存空間中分配的純字符數(shù)組。
                    char * buff = new char [sizeof (Foo) ];  
            ??? 一旦分配了緩沖,就能在緩沖中構(gòu)造每一種類型的對象。為此,使用特殊版本的new操作符(“定位new”),以緩沖地址為placement new的參數(shù)。為了使用placement new,必須包含標準頭文件<new>。下面的代碼片斷中,使用placement new操作在內(nèi)存地址buff上構(gòu)造類型為Foo的對象。
                    #include <new>
                    Foo * pfoo = new (buff) Foo; //使用new操作在buff上構(gòu)造一個 Foo?  
            ??? Placement new 以先前分配的緩沖(buff)地址作為參數(shù),并在這個緩沖上構(gòu)造給定類型的對象。他返回構(gòu)造對象的指針,這個對象指針的使用與通常的指針使用沒什么兩樣。
                    unsigned int length = pfoo->size();?
                    pfoo->resize(100, 200);
                    length = pfoo->size();?  
            ??? 當不再需要這個對象的時候,必須顯式調(diào)用其析構(gòu)函數(shù)釋放空間。做這件事是有一些技巧的,因為許多人錯誤地假設對象會被自動銷毀,錯也!。在預分配的緩沖里構(gòu)造另一個對象之前或者在釋放緩沖之前,如果忘了顯式調(diào)用析構(gòu)函數(shù),程序?qū)a(chǎn)生不可預料的后果。顯式的析構(gòu)器聲明如下:
                    pfoo->~Foo(); //顯式調(diào)用析構(gòu)函數(shù)  
            ??? 換句話說,一個顯式的析構(gòu)器與普通的成員函數(shù)調(diào)用一樣,只是名字與普通的成員函數(shù)稍有差別。一旦對象被銷毀,便可以在預分配的內(nèi)存中再次構(gòu)造另一個對象。實際上,這個過程可以無限制地重復:構(gòu)造一個對象,銷毀它,然后又反復利用預分配的緩沖構(gòu)造新對象。
            ??? 當不再需要預定義的緩沖時,或者說當應用程序關閉時,必須釋放預定義的緩沖。使用delete[]完成這個任務,因為預定義的緩沖是一個字符數(shù)組。下列代碼包含一個完整的例子的所有步驟,包括最終緩沖的釋放:
            #include <new>
            
              void placement_demo()
              { 
                //1. 預分配緩沖
                char * buff = new char [sizeof (Foo) ];  
            
                //2. 使用 placement new
                Foo * pfoo = new (buff) Foo;  
                
                //使用對象
                unsigned int length = pfoo->size();  
                pfoo->resize(100, 200);
            
                //3. 顯式調(diào)用析構(gòu)函數(shù)
                pfoo->~Foo();  
                
                //4. 釋放預定義的緩沖
                delete [] buff;  
              }

            posted on 2006-12-27 10:10 blues 閱讀(118) 評論(0)  編輯 收藏 引用

            国产午夜福利精品久久| 国产精品久久久久9999高清| 亚洲欧美日韩精品久久亚洲区| 精品精品国产自在久久高清 | 久久99免费视频| 久久最近最新中文字幕大全| 久久久久亚洲?V成人无码| 成人综合久久精品色婷婷| 久久天天躁狠狠躁夜夜96流白浆| 精品久久久久久久久中文字幕| 精品久久人人妻人人做精品| 亚洲欧美日韩中文久久| 久久久久99精品成人片牛牛影视| 久久国产精品成人影院| 午夜精品久久久久久影视777| 97久久久久人妻精品专区| 久久久久亚洲AV成人网人人网站 | 日韩久久久久久中文人妻| 国产一区二区三精品久久久无广告 | 国产激情久久久久久熟女老人| 精品久久一区二区| 国产亚洲精久久久久久无码77777 国产亚洲精品久久久久秋霞 | 国产99久久九九精品无码| 久久久久99精品成人片试看| 青青草国产97免久久费观看| 亚洲国产成人久久精品影视 | 久久精品无码专区免费| 国产精品毛片久久久久久久| 婷婷综合久久中文字幕蜜桃三电影| 国产毛片久久久久久国产毛片| 久久99精品综合国产首页| 97久久精品国产精品青草| 国内精品伊人久久久久av一坑| 亚洲AV日韩精品久久久久久久| 色综合久久中文字幕综合网| 久久久WWW成人| 久久青青国产| 亚洲欧美一区二区三区久久| 亚洲国产天堂久久综合| 久久国产免费直播| 久久精品无码一区二区无码 |