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

            我輩豈是蓬蒿人!

            C++ && keyWordSpotting

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              11 Posts :: 0 Stories :: 4 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(9)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 7091
            • 排名 - 1377

            最新評論

            閱讀排行榜

            評論排行榜

            ??
            ???動態(tài)分配的對象:程序員完全控制分配與釋放,分配在程序的空閑存儲區(qū)(free store)的可用內(nèi)存池中。
            ?
            ?1
            )單個對象的動態(tài)分配與釋放;
            ?new
            表達式?jīng)]有返回實際分配的對象,而是返回指向該對象的指針。對該對象的全部操作都要通過這個指針間接完成。
            ?
            隨機分配的內(nèi)存具有隨機的位模式,建議初始化,例如:

            ?int* pi = new int(0);


            ?

            空閑存儲區(qū)是有限的資源,若被耗盡,new表達式會失敗,拋出bad_alloc異常。
            ?
            這樣做沒有必要:

            ???? if ?(?pi?!=?0?)
            ????????delete?pi;

            ? 說明:如果指針操作數(shù)被設置為0,則C++保證delete表達式不會調(diào)用操作符delete()。所以沒有必要測試其是否為0
            ?
            delete表達式之后,pi被稱作空懸指針,即指向無效內(nèi)存的指針。空懸指針是程序錯誤的根源,建議對象釋放后,將該指針設置為0
            ?
            ?2
            auto_ptr
            ?auto_ptr
            C++標準庫提供的類模板,它可以幫助程序員自動管理用new表達式動態(tài)分配的單個對象,但是,它沒有對數(shù)組管理提供類似支持。它的頭文件為:
            ?

            ????#include? < memory > ?

            ? auto_ptr對象的生命期結(jié)束時,動態(tài)分配的對象被自動釋放。
            ?auto_ptr
            類模板背后的主要動機是支持與普通指針類型相同的語法,但是為auto_ptr對象所指對象的釋放提供自動管理。例:

            ???? //? 第一種初始化形式
            ????std::auto_ptr< int >?pi(? new ? int (1024)?);???? //?

            ?auto_ptr 類模板支持所有權概念,當一個auto_ptr對象被用另一個auto_ptr對象初始化賦值時,左邊被賦值或初始化的對象就擁有了空閑存儲區(qū)內(nèi)底層對象的所有權,而右邊的auto_ptr對象則撤消所有責任。例:

            ????std::auto_ptr<std:: string >?pstr_auto(? new ?std:: string (?"Brontonsaurus"?)?);
            ????
            //?
            第二種初始化形式
            ????std::auto_ptr<std:: string >?pstr_auto2(?pstr_auto?);

            ? 判斷是否指向一個對象,例:

            ???? // ?第三種初始化形式
            ????auto_ptr < int > ?p_auto_int;????
            ????
            if ?(?p_auto_int. get ()? == ? 0 ?)
            ????????
            ????
            else
            ????????
            // ?重置底層指針,必須使用此函數(shù)????????
            ????????p_auto_int.reset(? new ? int (? 1024 ?)?);


            ?3)數(shù)組的動態(tài)分配與釋放
            ?
            建議使用C++標準庫string,避免使用C風格字符串數(shù)組。
            ?
            為避免動態(tài)分配數(shù)組的內(nèi)存管理帶來的問題,一般建議使用標準庫vectorliststring容器類型。
            ?
            ?4
            )常量對象的動態(tài)分配與釋放
            ?
            可以使用new表達式在空閑存儲區(qū)內(nèi)創(chuàng)建一個const對象,例:

            ???? //? 此時必須初始化,否則編譯錯誤
            ???? const ? int *?pci?=? new ? const ? int (1024);????

            ? 我們不能在空閑存儲區(qū)創(chuàng)建內(nèi)置類型元素的const數(shù)組,原因是:我們不能初始化用new表達式創(chuàng)建的內(nèi)置類型數(shù)組的元素。例:

            ???? const ? int *?pci?=? new ? const ? int [100];? //? 編譯錯誤


            ?5
            )定位new表達式
            ?new
            表達式的第三種形式允許程序員要求將對象創(chuàng)建在已經(jīng)被分配好的內(nèi)存中。稱為:定位new表達式(placement new expression)。程序員在new表達式中指定待創(chuàng)建對象所在的內(nèi)存地址。如下所示:
            ?new
            place_address) type-specifier
            ?
            注意:place_address必須是個指針,必須包含頭文件<new>。這項設施允許程序員預分配大量的內(nèi)存,供以后通過這種形式的new表達式創(chuàng)建對象。例如:

            ????#include? < iostream >
            ????#include?
            < new > ???? // ?必須包含這個頭文件
            ????
            ????
            const ? int ?chunk? = ? 16 ;
            ????
            class ?Foo
            ????
            {
            ????????
            ????}
            ;
            ????
            ????
            char * ?buf? = ? new ? char [? sizeof (Foo)? * ?chunk?];
            ????
            ????
            int ?main( int ?argc,? char * ?argv[])
            ????
            {
            ????????
            // ?只有這種形式的創(chuàng)建,沒有配對形式的delete?
            ????????Foo * ?pb? = ? new ?(buf)?Foo;
            ????????????????
            ????????delete[]?buff;
            ????????
            ????????
            return ? 0 ;
            ????}

            posted on 2006-08-22 14:54 keyws 閱讀(592) 評論(3)  編輯 收藏 引用 所屬分類: 讀書筆記

            Feedback

            # re: 【note】《C++ Primer - 8.4節(jié)“動態(tài)分配的對象”》學習筆記 2006-09-22 13:22 feifei
            有沒有--編譯過無誤的《C++ Primer >>第三版源代碼?---幫下偶
            l  回復  更多評論
              

            # re: 【note】《C++ Primer - 8.4節(jié)“動態(tài)分配的對象”》學習筆記 2006-09-24 14:11 keyws
            @feifei
            還真的沒有,我看《C++ primer》時,感興趣的就自己敲一下,也沒有刻意去找現(xiàn)成的源代碼。
              回復  更多評論
              

            # 提個建議 2008-12-22 07:57 云川
            {
            // 只有這種形式的創(chuàng)建,沒有配對形式的delete
            Foo * pb = new (buf) Foo;
            //因為沒有配對形式的delete 所以要顯式的調(diào)用對象的析構(gòu)函數(shù)
            //否則在存儲池析構(gòu)以后調(diào)用對象會出錯(此時系統(tǒng)并不認為對象已析構(gòu))
            pb->~Foo();
            delete[] buff;

            return 0 ;
            }   回復  更多評論
              

            久久av免费天堂小草播放| 成人久久综合网| 亚洲精品乱码久久久久久不卡| 少妇内射兰兰久久| 久久福利青草精品资源站免费 | 亚洲人成电影网站久久| 久久精品国产精品亜洲毛片| 久久夜色精品国产噜噜亚洲a| 精品久久久久久无码人妻蜜桃 | 亚洲午夜福利精品久久| 色欲综合久久中文字幕网| 久久成人国产精品二三区| 久久受www免费人成_看片中文| 欧美国产成人久久精品| 久久久噜噜噜久久熟女AA片 | 噜噜噜色噜噜噜久久| 久久成人影院精品777| 日本五月天婷久久网站| 国产精品99久久久久久宅男| 亚洲色婷婷综合久久| 2021最新久久久视精品爱| 夜夜亚洲天天久久| 久久精品aⅴ无码中文字字幕不卡| 国产精品久久久久久久| 亚洲精品国产字幕久久不卡| 日韩精品无码久久一区二区三| 久久久久亚洲Av无码专| 国产精品久久久久蜜芽| 久久久免费观成人影院| 国产精品狼人久久久久影院| 久久精品一区二区三区不卡| 香蕉久久夜色精品升级完成| 狠狠色丁香久久婷婷综合图片| 久久精品国内一区二区三区| 久久国产乱子伦精品免费强| 97久久超碰国产精品旧版| 国内精品久久久久影院优| 麻豆AV一区二区三区久久| 久久精品中文无码资源站| 久久久久无码精品国产| 国产午夜福利精品久久2021|