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

            Life & Code

            代碼是咒語(yǔ),我是魔法師

            ACE的內(nèi)存管理

            分配器?
            描述

            ACE_Allocator?
            ACE中的分配器類的接口類。這些類使用繼承和動(dòng)態(tài)綁定來(lái)提供靈活性。

            ACE_Static_Allocator?
            該分配器管理固定大小的內(nèi)存。每當(dāng)收到分配內(nèi)存的請(qǐng)求時(shí),它就移動(dòng)內(nèi)部指針、以返回內(nèi)存chunk(“大塊”)。它還假定內(nèi)存一旦被分配,就再也不會(huì)被釋放。

            ACE_Cached_Allocator?
            該分配器預(yù)先分配內(nèi)存池,其中含有特定數(shù)目和大小的內(nèi)存chunk。這些chunk在內(nèi)部空閑表(free list)中進(jìn)行維護(hù),并在收到內(nèi)存請(qǐng)求(malloc())時(shí)被返回。當(dāng)應(yīng)用調(diào)用free()時(shí),chunk被歸還到內(nèi)部空閑表、而不是OS中。

            ACE_New_Allocator?
            為C++ new和delete操作符提供包裝的分配器,也就是,它在內(nèi)部使用new和delete操作符,以滿足動(dòng)態(tài)內(nèi)存請(qǐng)求。

            #include? " ace/Malloc.h "

            // A?chunk?of?size?1K?is?created.?In?our?case?we?decided?to?use?a?simple?array

            // as?the?type?for?the?chunk.?Instead?of?this?we?could?use?any?struct?or?class

            // that?we?think?is?appropriate.

            typedef?
            char ?MEMORY_BLOCK[ 1024 ];
            // Create?an?ACE_Cached_Allocator?which?is?passed?in?the?type?of?the

            // “chunk”?that?it?must?pre-allocate?and?assign?on?the?free?list.

            // ?Since?the?Cached_Allocator?is?a?template?class?we?can?pretty?much

            // pass?it?ANY?type?we?think?is?appropriate?to?be?a?memory?block.

            typedef?ACE_Cached_Allocator
            < MEMORY_BLOCK,ACE_SYNCH_MUTEX > ?Allocator;

            class ?MessageManager

            {

            public :

            ????
            // The?constructor?is?passed?the?number?of?chunks?that?the?allocator

            ????
            // should?pre-allocate?and?maintain?on?its?free?list.

            ????MessageManager(
            int ?n_blocks):

            ??????allocator_(n_blocks),message_count_(
            0 )

            ??????
            {

            ??????????mesg_array_
            = new ? char * [n_blocks];

            ??????}
            // Allocate?memory?for?a?message?using?the?Allocator.?Remember?the?message
            ??????
            // in?an?array?and?then?increase?the?message?count?of?valid?messages
            ??????
            // on?the?message?array.
            ?????? void ?allocate_msg( const ? char ? * msg)
            ??????
            {
            ????????mesg_array_[message_count_]
            = ( char * )allocator_.malloc(ACE_OS::strlen(msg) + 1 );

            ??????????ACE_OS::strcpy(mesg_array_[message_count_],msg);

            ??????????message_count_
            ++ ;

            ??????}


            ???????

            ??????
            // Free?all?the?memory?that?was?allocated.?This?will?cause?the?chunks

            ??????
            // to?be?returned?to?the?allocator’s?internal?free?list

            ??????
            // and?NOT?to?the?OS.

            ??????
            void ?free_all_msg()

            ??????
            {

            ??????????
            for ( int ?i = 0 ;i < message_count_;i ++ )

            ??????????????allocator_.free(mesg_array_[i]);

            ???????????

            ??????????message_count_
            = 0 ;

            ??????}


            ???????

            ??????
            // Just?show?all?the?currently?allocated?messages?in?the?message?array.

            ??????
            void ?display_all_msg()

            ??????
            {

            ??????????
            for ( int ?i = 0 ;i < message_count_;i ++ )

            ??????????????ACE_OS::printf(
            " %s\n " ,mesg_array_[i]);

            ??????}


            ???????

            private :

            ????
            char ? ** mesg_array_;

            ????Allocator?allocator_;

            ????
            int ?message_count_;

            }
            ;

            ?

            int ?main( int ?argc,? char * ?argv[])

            {

            ????
            char ?message[ 512 ]? = ? { 0 ????} ;
            ????
            if (argc < 2 )

            ????
            {

            ????????ACE_DEBUG((LM_DEBUG,?
            " Usage:?%s?<Number?of?blocks>\n " ,?argv[ 0 ]));

            ????????exit(
            1 );

            ????}


            ?????

            ????
            int ?n_blocks = ACE_OS::atoi(argv[ 1 ]);

            ?????

            ????
            // Instantiate?the?Memory?Manager?class?and?pass?in?the?number?of?blocks

            ????
            // you?want?on?the?internal?free?list.

            ????MessageManager?mm(n_blocks);

            ????
            // Use?the?Memory?Manager?class?to?assign?messages?and?free?them.

            ????
            // Run?this?in?your?favorite?debug?environment?and?you?will?notice?that?the

            ????
            // amount?of?memory?your?program?uses?after?Memory?Manager?has?been

            ????
            // instantiated?remains?the?same.?That?means?the?Cached?Allocator

            ????
            // controls?or?manages?all?the?memory?for?the?application.

            ????
            // Do?forever.

            ????
            while ( 1 )

            ????
            {

            ????????
            // allocate?the?messages?somewhere

            ????????ACE_DEBUG((LM_DEBUG,
            " \n\n\nAllocating?Messages\n " ));

            ????????
            for ( int ?i = 0 ;?i < n_blocks;i ++ ) {

            ????????????ACE_OS::sprintf(message,
            " Message?%d:?Hi?There " ,i);
            ????????????mm.allocate_msg(message);

            ????????}


            ?????????

            ????????
            // show?the?messages

            ????????ACE_DEBUG((LM_DEBUG,
            " Displaying?the?messages\n " ));

            ????????Sleep(
            2 );

            ????????mm.display_all_msg();

            ?????????

            ????????
            // free?up?the?memory?for?the?messages.

            ????????ACE_DEBUG((LM_DEBUG,
            " Releasing?Messages\n " ));

            ????????Sleep(
            2 );


            ????????mm.free_all_msg();

            ????}

            ????
            return ? 0 ;
            }



            內(nèi)存池:

            ACE_MMAP_Memory_Pool?
            ACE_MMAP_MEMORY_POOL?
            使用<mmap(2)>創(chuàng)建內(nèi)存池。這樣內(nèi)存就可在進(jìn)程間共享了。每次更新時(shí),內(nèi)存都被更新到后備存儲(chǔ)(backing store)。

            ACE_Lite_MMAP_Memory_Pool?
            ACE_LITE_MMAP_MEMORY_POOL?
            使用<mmap(2)>創(chuàng)建內(nèi)存池。不像前面的映射,它不做后備存儲(chǔ)更新。代價(jià)是較低可靠性。

            ACE_Sbrk_Memory_Pool?
            ACE_SBRK_MEMORY_POOL?
            使用<sbrk(2)>調(diào)用創(chuàng)建內(nèi)存池。

            ACE_Shared_Memory_Pool?
            ACE_SHARED_MEMORY_POOL?
            使用系統(tǒng)V <shmget(2)>調(diào)用創(chuàng)建內(nèi)存池。

            Memory_Pool? ?
            內(nèi)存可在進(jìn)程間共享。

            ACE_Local_Memory_Pool?
            ACE_LOCAL_MEMORY_POOL?
            通過(guò)C++的new和delete操作符創(chuàng)建局部?jī)?nèi)存池。該池不能在進(jìn)程間共享。

            ?

            #include?? " ace/Malloc.h " ?
            #include??
            " ace/Malloc_T.h " ?
            #include??
            " ace/Null_Mutex.h "

            #include?
            < ACE / MMAP_Memory_Pool.h >

            typedef?ACE_Malloc
            < ACE_MMAP_Memory_Pool,ACE_Null_Mutex? > ?Malloc;

            void ??ReadData();
            void ??WriteData();

            Malloc?
            * g_mem;
            int ?main( int ?arn, char ? ** arc)
            {
            ????ACE_MMAP_Memory_Pool_Options?options(ACE_DEFAULT_BASE_ADDR,
            ????????ACE_MMAP_Memory_Pool_Options::ALWAYS_FIXED,
            ????????????????
            1024 * 10000 );

            ????ACE_NEW_RETURN(g_mem,Malloc(
            " abc " , " abc " , & options), - 1 );
            ????
            if (?????arn? > ? 1 )
            ????
            {
            ????????ReadData();
            ????}

            ????
            else
            ????
            {
            ????????WriteData();
            ????}

            ????system(
            " pause " );
            ????g_mem
            -> sync();
            ????delete?g_mem;
            ????
            return ? 0 ;
            }


            void ??ReadData()
            {
            ????
            char ?msg[ 32 ]? = { 0 } ;
            ????
            void ? * data;
            ????
            ????
            for ( int ?i = ? 0 ;i < ? 10000 ;i ++ )
            ????
            {
            ????????sprintf(msg,
            " MSG:?%d " ,i);
            ????????
            if (g_mem -> find(msg,data)? != ? - 1 )
            ????????
            {
            ????????????ACE_DEBUG((LM_INFO,
            " %s\n " ,( char * )data));
            ????????}

            ????}

            ????
            }


            void ?WriteData()
            {
            ????
            ????
            for ( int ?i = 0 ;i < 10000 ;i ++ )
            ????
            {
            ????????
            char * ?buff? = ?( char * )g_mem -> malloc( 1024 );
            ????????
            if (buff? != ?NULL)
            ????????
            {
            ????????????sprintf(buff,
            " MSG:?%d " ,i);
            ????????????g_mem
            -> bind(buff,( void * )buff);
            ????????}

            ????}

            }


            通過(guò)分配器接口使用Malloc類

              大多數(shù)ACE中的容器類都可以接受分配器對(duì)象作為參數(shù),以用于容器內(nèi)的內(nèi)存管理。因?yàn)槟承﹥?nèi)存分配方案只能用于ACE_Malloc類集,ACE含有一個(gè)適配器模板類ACE_Allocator_Adapter,它將ACE_Malloc類適配到ACE_Allocator接口。也就是說(shuō),在實(shí)例化這個(gè)模板之后創(chuàng)建的新類可用于替換任何ACE_Allocator。例如:

             

            typedef ACE_Allocator_Adapter<ACE_Malloc<ACE_SHARED_MEMORY_POOL,ACE_Null_Mutex>> Allocator;

            posted on 2006-08-30 14:43 橙子 閱讀(2369) 評(píng)論(0)  編輯 收藏 引用 所屬分類: ACE

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(10)

            隨筆分類

            隨筆檔案

            相冊(cè)

            收藏夾

            搜索

            最新評(píng)論

            閱讀排行榜

            久久91精品久久91综合| 狠狠人妻久久久久久综合蜜桃| 99久久国产热无码精品免费久久久久| 精品久久久中文字幕人妻| 99久久香蕉国产线看观香| 国产精品亚洲综合久久| 久久无码AV一区二区三区| 久久久久久久精品成人热色戒| 精品久久久无码中文字幕天天| 久久精品无码av| 久久最新免费视频| 亚洲欧美久久久久9999| 国产毛片欧美毛片久久久| 久久天天躁狠狠躁夜夜96流白浆 | 久久久久一区二区三区| 九九久久99综合一区二区| 97精品国产97久久久久久免费| 91精品无码久久久久久五月天| 91亚洲国产成人久久精品网址| 日本欧美国产精品第一页久久| 久久91精品国产91| 久久精品国产99久久久| 99久久精品九九亚洲精品| 久久中文精品无码中文字幕| 亚洲日本va中文字幕久久| 久久九九青青国产精品| 亚洲欧美日韩久久精品| 无码人妻少妇久久中文字幕蜜桃| 999久久久无码国产精品| 久久久国产精品| 久久久女人与动物群交毛片| 国产精品美女久久久久AV福利 | 99蜜桃臀久久久欧美精品网站| 91精品国产高清91久久久久久| 久久中文字幕视频、最近更新| 国产aⅴ激情无码久久| 国产 亚洲 欧美 另类 久久| 77777亚洲午夜久久多喷| 久久精品综合一区二区三区| 久久青青草原精品国产| 亚洲精品高清一二区久久|