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

            A Za, A Za, Fighting...

            堅信:勤能補(bǔ)拙

            operator new/delete與 new/delete operator

            C++中的operator new與new operator,看上去挺像的兩姐妹,卻有天壤之別。

            operator new

            (1) 只分配所要求的空間,不調(diào)用相關(guān)對象的構(gòu)造函數(shù)。當(dāng)無法滿足所要求分配的空間時,則

                    ->如果有new_handler,則調(diào)用new_handler,否則

                    ->如果沒要求不拋出異常(以nothrow參數(shù)表達(dá)),則執(zhí)行bad_alloc異常,否則

                    ->返回0

            (2) 可以被重載

            (3) 重載時,返回類型必須聲明為void*

            (4) 重載時,第一個參數(shù)類型必須為表達(dá)要求分配空間的大?。ㄗ止?jié)),類型為size_t

            (5) 重載時,可以帶其它參數(shù)

            new operator

            (1) 調(diào)用operator new分配足夠的空間,并調(diào)用相關(guān)對象的構(gòu)造函數(shù)

            (2) 不可以被重載

            相應(yīng)地,operator delete與delete operator有相似的特性。

            舉個例子

            class X
            {
            public:
            …………
                static void* operator new(size_t size)
            {
                return ::operator new(size);
            }
            static void operator delete(void* pointee)
            {
                ::operator delete(pointee);
            }
            …………
            };
            X* px = new X();

            該行代碼中的new為new operator,它將調(diào)用類X中的operator new,為該類的對象分配空間,然后調(diào)用當(dāng)前實例的構(gòu)造函數(shù)。

            delete px;

            該行代碼中的delete為delete operator,它將調(diào)用該實例的析構(gòu)函數(shù),然后調(diào)用類X中的operator delete,以釋放該實例占用的空間。

            new operator與delete operator的行為是不能夠也不應(yīng)該被改變,這是C++標(biāo)準(zhǔn)作出的承諾。而operator new與operator delete和C語言中的malloc與free對應(yīng),只負(fù)責(zé)分配及釋放空間。但使用operator new分配的空間必須使用operator delete來釋放,而不能使用free,因為它們對內(nèi)存使用的登記方式不同。反過來亦是一樣。

            你可以重載operator new和operator delete以實現(xiàn)對內(nèi)存管理的不同要求,但你不能重載new operator或delete operator以改變它們的行為。

            當(dāng)重載operator new時,可以提供更多的參數(shù),在new一個對象時,通過在關(guān)鍵字new后的括號傳遞額外的參數(shù)。比如以下的類

            class A
            {
            public:
                …………
                static void* operator new(size_t size, const string& example)
            {
                cout << example << endl;
                return ::operator new(size);
            }
            …………
            };
            A* pa = new (“This will be printed out in operator new”) A();

            新標(biāo)準(zhǔn)的C++允許以這樣的方式傳遞一個名為nothrow的參數(shù),以表明當(dāng)為該對象分配空間失敗時,不拋出異常,而是返回0,以兼容舊標(biāo)準(zhǔn)new的行為。比如

            class B {};
            B* pb = new (nothrow) B();

            當(dāng)然這只能對那些使用默認(rèn)operator new操作符的類。對已經(jīng)重載了operator new的類(比如上面的X和A),如果不聲明能接受nothrow參數(shù),自然無法享受C++標(biāo)準(zhǔn)帶來的禮物。

            --------

            我們經(jīng)常看到這么一句話: operator new 可以重載, placement new 不可重載。其實此處所說的不可重載應(yīng)該是指全局的 placement new 不可重載,對于類域中的 placement new 是可以重載的,而且只要重載了任何一種形式的 operator new 都應(yīng)該順便重載 placement new , 即 void * operator new(std::size_t count, void *ptr) 。

            操作符重載一般用于特定類型,名字解析過程同一般的函數(shù)重載。 Operator new 由于其特殊性,編譯器提供了默認(rèn)提供 6 種全局重載形式,同時還允許用戶提供自定義的全局 operator new ,其參數(shù)甚至可以和全局版本一樣,除全局 placement new 外。對于類域,任何形式的 new 都是可以重載的,包括 placement new 形式。

             

            全局的 operator new( 函數(shù) ) 有六種重載形式

            void *operator new(std::size_t count)

                throw(std::bad_alloc);           // 一般的版本

             

            void *operator new(std::size_t count,   // 兼容早版本的 new

                const std::nothrow_t&) throw();   // 內(nèi)存分配失敗不會拋出異常

             

            void *operator new(std::size_t count, void *ptr) throw();  //placement 版本

                                                  

            void *operator new[](std::size_t count)  //

                throw(std::bad_alloc);

             

            void *operator new[](std::size_t count,  //

                const std::nothrow_t&) throw();

             

            void *operator new[](std::size_t count, void *ptr) throw();

             

            重載 operator new 規(guī)則

            重載 operator new 的參數(shù)個數(shù)是可以任意的 , 只需要保證第一個參數(shù)為 size_t, 返回類型為 void * 即可 , 而且其重載的參數(shù)類型也不必包含自定義類型 . 更一般的說 , operator new 的重載更像是一個函數(shù)的重載 , 而不是一個操作符的重載 . 如:

             

            全局重載示例:

            void* operator new(size_t size)  // 重載成功

            {

               printf("global new\n");

               return malloc(size);

               //return ::operator new(size);  // 遞歸調(diào)用提示 (warning)

            }

             

            //void *operator new(std::size_t size, void *ptr) // 無法重載

            //{

            //     printf("global new\n");

            //     return ::operator new(size,ptr);

            //}

             

            void * operator new(size_t size, const std::nothrow_t& e) // 重載成功 , 遞歸調(diào)用提示 (warning)

            {

                   printf("global new\n");

                   return ::operator new(size, e);

            }

             

            一般形式的 operator new 重載示例:

            void * operator new(size_t size, int x, int y, int z)

            {

                ...

            }

            X * pX = new (1, 2, 3) X;

             

            char data[1000][sizeof(foo)];

            inline void* operator new(size_t size, int n)

            {

                    return data[n];

            }

            就可以使用這樣有趣的語法來創(chuàng)建對象 :

            foo *p=new(6) foo(); // 把對象創(chuàng)建在 data 的第六個單元上  

            posted on 2011-05-24 14:12 simplyzhao 閱讀(470) 評論(0)  編輯 收藏 引用 所屬分類: Z_小小知識點(diǎn)

            導(dǎo)航

            <2011年5月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            統(tǒng)計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            九九精品99久久久香蕉| 伊人久久大香线蕉精品不卡| 嫩草伊人久久精品少妇AV| 国产精品一久久香蕉产线看| 91久久成人免费| 久久99精品久久久大学生| 久久精品国产影库免费看| 无码人妻久久一区二区三区蜜桃 | 国内精品久久久久久久亚洲| 青青热久久国产久精品 | 亚洲精品乱码久久久久久中文字幕 | 色欲综合久久躁天天躁蜜桃| 久久久国产精品| 久久免费视频观看| 免费精品久久天干天干| 久久99精品久久久久久9蜜桃| 久久A级毛片免费观看| 2019久久久高清456| 性做久久久久久久久浪潮| 精品久久久久久国产三级 | 国产成年无码久久久久毛片| 久久亚洲中文字幕精品一区四 | 伊人久久综在合线亚洲2019| 国内精品久久久久影院优| 无码国内精品久久人妻蜜桃| 日本亚洲色大成网站WWW久久| 精品视频久久久久| 久久国产精品视频| 久久久久亚洲精品男人的天堂 | 精品久久久久久久| 色88久久久久高潮综合影院| 久久夜色精品国产噜噜噜亚洲AV| 国产精品久久久久蜜芽| 久久人人爽人人爽人人片AV高清 | 亚洲国产成人久久综合碰碰动漫3d| 人妻少妇久久中文字幕一区二区| 亚洲中文字幕无码久久精品1| 少妇高潮惨叫久久久久久| 久久久久国产精品熟女影院| 亚洲AV无码久久| 狠狠狠色丁香婷婷综合久久俺|