• <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>
            隨筆 - 26  文章 - 6  trackbacks - 0
            <2009年7月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            朋友

            • cqh
            • 大學室友...

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            如果不滿足內存分配請求時,不斷重復調用new-handler函數
            當前的new-handler可以利用set_new_handler安裝新的new-handler取代它。

            ////////////////////////////////////////////////////////////
            //
            //FileName : lianxi.cpp
            //Creator  : longshen
            //Date : 2009-7-17
            //Commet : 處理內存不夠
            //
            ////////////////////////////////////////////////////////////
            #include <new>
            #include 
            <iostream>

            using namespace std;


            /**
            * @brief    內存不夠的處理    
            * @return    __cdecl
            */

            void __cdecl noMoreMemory( )
            {
               cout 
            << "Unable to satisfy request for memory" << endl;
               
            throw bad_alloc( );
               
            return;
            }



            int main( ) 
            {
               
            //安裝新new-handler函數
                set_new_handler(noMoreMemory);        //The new handler is used by operator new
               try
               
            {
                  
            while ( 1 ) 
                  
            {
                     
            new int[5000000];
                     cout 
            << "Allocating 5000000 ints." << endl;
                  }

               }

               
            catch (exception e)
               
            {
                  cout 
            << e.what( ) << endl;
               }

               
            return 0;
            }



               C++不支持專門針對類的new-handler函數,我們可以自己來實現它

            ////////////////////////////////////////////////////////////
            //
            //FileName : lianxi.cpp
            //Creator  : longshen
            //Date : 2009-7-17
            //Commet : 處理內存不夠
            //
            ////////////////////////////////////////////////////////////
            #include <new>
            #include 
            <iostream>

            using namespace std;


            /**
            * @brief    內存不夠的處理    
            * @return    __cdecl
            */

            void __cdecl noMoreMemory( )
            {
               cout 
            << "Unable to satisfy request for memory" << endl;
               
            throw bad_alloc( );
               
            return;
            }



            class Kx
            {
                
            public:
                    
            static new_handler set_new_handler(new_handler p);
                    
            static void* operator new(size_t size);
                    
            int a[10000000];
                
            private:
                    
            static new_handler currentHandler;
            }
            ;


            /**
            * @brief    設置類的currentHandler,并返回舊的new-handler
            * @param    p    輸入的new-handler函數
            * @return    返回舊的new-handler
            */

            new_handler Kx::set_new_handler(new_handler p)
            {
                new_handler oldHandler 
            = currentHandler;
                currentHandler 
            = p;
                
            return oldHandler;
            }



            /**
            * @brief    缺省設置currentHandler為0(即null)
            * @return    返回new-handler函數地址
            */

            new_handler Kx::currentHandler;      
            // 缺省設置currentHandler為0(即null)


            /**
            * @brief    重載new
            * @param    size 申請要開辟內存的大小
            * @return    內存空間指針
            */

            void* Kx::operator new(size_t size)
            {
                new_handler globalHandler 
            =                        // 安裝Kx的new_handler
                    std::set_new_handler(currentHandler);

                
            void* memory;
                
            //嘗試分配內存
                try
                
            {
                    memory 
            = ::operator new(size);
                }

                
            catch(std::bad_alloc&)
                
            {
                    std::set_new_handler(globalHandler);    
            //恢復舊的new_handler
                    throw;                                //拋出異常
                }


                std::set_new_handler(globalHandler);        
            //恢復舊的new_handler
                
                
            return memory;
            }



            int main()
            {
                
                
            try {
                    
            while(1)
                    
            {
                        
            //把noMoreMemroy設置為Kx的new-handling函數
                        Kx::set_new_handler(noMoreMemory);            
                        

                        Kx
            * pkx = new Kx;            //如果內存分配失敗,調用noMoreMemory


                        
            string* pszStr = new string//如果內存分配失敗,調用全局new-handling函數

                        
            //設Kx的new-handling函數為空
                        Kx::set_new_handler(0);        

                        Kx
            * pkx2 = new Kx;        //如果內存分配失敗,立即拋出異常
                                                
            //類Kx沒有new-handling函數

                        cout 
            << "Allocating 20000000 ints." << endl;
                    }

                }

                
            catch ( exception e )
                
            {
                    cout 
            << e.what( ) << endl;
                }

                
            return 0;
            }




             

            posted on 2009-07-17 16:23 longshen 閱讀(675) 評論(0)  編輯 收藏 引用 所屬分類: VC++
            久久精品国产久精国产一老狼| 99久久精品九九亚洲精品| 国产精品99久久久精品无码| 久久久噜噜噜久久中文字幕色伊伊| 91麻豆国产精品91久久久| 蜜臀久久99精品久久久久久小说| 亚洲国产精品热久久| 一本一道久久a久久精品综合 | 久久嫩草影院免费看夜色| 久久受www免费人成_看片中文| 国产午夜久久影院| 性欧美大战久久久久久久久| 久久久国产精品| 99久久国产综合精品麻豆| 亚洲欧美国产日韩综合久久| 精品久久久久久久| 久久夜色精品国产噜噜噜亚洲AV| 久久国产视频99电影| 99久久精品免费看国产一区二区三区 | 亚洲午夜精品久久久久久app| 国产成人久久精品激情| 亚洲精品综合久久| 久久99精品久久久久久不卡| 国产午夜久久影院| 99久久精品日本一区二区免费| 久久久久久久久久久精品尤物 | 久久99毛片免费观看不卡| 亚洲精品高清国产一线久久| 一级a性色生活片久久无| 久久黄色视频| 久久久久国产亚洲AV麻豆| 国产精品美女久久久免费 | 亚洲精品乱码久久久久久蜜桃| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 久久国产成人午夜aⅴ影院| 国产婷婷成人久久Av免费高清| 日韩人妻无码一区二区三区久久| 久久99热这里只频精品6| 精品伊人久久大线蕉色首页| 亚洲国产另类久久久精品黑人| 亚洲精品蜜桃久久久久久|