• <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++ 技術中心

               :: 首頁 :: 聯系 ::  :: 管理
              160 Posts :: 0 Stories :: 87 Comments :: 0 Trackbacks

            公告

            鄭重聲明:本BLOG所發表的原創文章,作者保留一切權利。必須經過作者本人同意后方可轉載,并注名作者(天空)和出處(CppBlog.com)。作者Email:coder@luckcoder.com

            留言簿(27)

            搜索

            •  

            最新隨筆

            最新評論

            評論排行榜



            引言

            C/C++下內存管理是讓幾乎每一個程序員頭疼的問題,分配足夠的內存、追蹤內存的分配、在不需要的時候釋放內存——這個任務相當復雜。而直接使用系統調用malloc/free、new/delete進行內存分配和釋放,有以下弊端:

            1. 調用malloc/new,系統需要根據“最先匹配”、“最優匹配”或其他算法在內存空閑塊表中查找一塊空閑內存,調用free/delete,系統可能需要合并空閑內存塊,這些會產生額外開銷
            2. 頻繁使用時會產生大量內存碎片,從而降低程序運行效率
            3. 容易造成內存泄漏


            內存池(memory pool)是代替直接調用malloc/freenew/delete進行內存管理的常用方法,當我們申請內存空間時,首先到我們的內存池中查找合適的內存塊,而不是直接向操作系統申請,優勢在于:

            1. 比malloc/free進行內存申請/釋放的方式快
            2. 不會產生或很少產生堆碎片
            3. 可避免內存泄漏


            內存池設計

            看到內存池好處這么多,是不是恨不能馬上拋棄malloc/free,投奔內存池的懷抱呢?且慢,在我們自己動手實現內存池之前還需要明確以下幾個問題:

            1. 內存池的空間如何獲得?是程序啟動時分配一大塊空間還是程序運行中按需求分配?
            2. 內存池對到來的內存申請,有沒有大小的限制?如果有,最小可申請的內存塊為多大,最大的呢?
            3. 如何合理設計內存塊結構,方便我們進行內存的申請、追蹤和釋放呢?
            4. 內存池占用越多空間,相對應其他程序能使用的內存就越少,是否要設定內存池空間的上限?設定為多少合適呢?

             

            帶著以上問題,我們來看以下一種內存池設計方案。


            內存池實現方案一

            這里下載該內存池實現的源碼。

            首先給出該方案的整體架構,如下:

            圖1.內存池架構圖

            結構中主要包含blocklist和pool這三個結構體,block結構包含指向實際內存空間的指針,前向和后向指針讓block能夠組成雙向鏈表;list結構中free指針指向空閑 內存塊組成的鏈表,used指針指向程序使用中的內存塊組成的鏈表,size值為內存塊的大小,list之間組成單向鏈表;pool結構記錄list鏈表的頭和尾。


            內存跟蹤策略

            該方案中,在進行內存分配時,將多申請12個字節,即實際申請的內存大小為所需內存大小+12。在多申請的12個字節中,分別存放對應的list指針(4字節)、used指針(4字節)和校驗碼(4字節)。通過這樣設定,我們很容易得到該塊內存所在的list和block,校驗碼起到粗略檢查是否出錯的作用。該結構圖示如下:



            圖2.內存塊申請示意圖

            圖中箭頭指示的位置為內存塊真正開始的位置。


            內存申請和釋放策略

            申請:根據所申請內存的大小,遍歷list鏈表,查看是否存在相匹配的size;

                存在匹配size:查看free時候為NULL

                  free為NULL:使用malloc/new申請內存,并將其置于used所指鏈表的尾部

                  free不為NULL:將free所指鏈表的頭結點移除,放置于used所指鏈表的尾部

                不存在匹配size:新建list,使用malloc/new申請內存,并將其置于該list的used所指鏈表尾部

               返回內存空間指針

            釋放:根據內存跟蹤策略,獲取list指針和used指針,將其從used指針所指的鏈表中刪除,放置于free指針所指向的鏈表


            對方案一的分析

            對照“內存池設計”一節中提出的問題,我們的方案一有以下特點:

            1. 程序啟動后內存池并沒有內存塊,到程序真正進行內存申請和釋放的時候才接管內存塊管理;
            2. 該內存池對到來的申請,對申請大小并不做限制,其為每個size值創建鏈表進行內存管理;
            3. 該方案沒有提供限定內存池大小的功能


            結合分析,可以得出該方案應用場景如下:程序所申請的內存塊大小比較固定(比如只申請/釋放1024bytes或2048bytes的內存),申請和釋放的頻率基本保持一致(因申請多而釋放少會占用過多內存,最終導致系統崩潰)。


            這篇文章講解了內存管理的基本知識,以一個簡單的內存池實現例子作為敲門磚,引領大家認識內存池,下一篇為內存池進階文章,講解apache服務器中內存池的實現方法。

            posted on 2013-03-16 13:06 C++技術中心 閱讀(3106) 評論(0)  編輯 收藏 引用 所屬分類: C++ 基礎
            久久亚洲国产中v天仙www| 久久精品国产2020| 久久综合九色综合欧美狠狠| 国产精品无码久久四虎| 久久婷婷人人澡人人| 中文字幕无码久久精品青草| 人妻精品久久久久中文字幕69 | 久久久久99精品成人片牛牛影视| 久久国产高清字幕中文| 欧美亚洲国产精品久久| 狠狠色丁香婷婷综合久久来 | 综合人妻久久一区二区精品| 人妻精品久久久久中文字幕69| 国产午夜精品久久久久九九| 麻豆av久久av盛宴av| 精品久久久久久久久中文字幕| 亚洲国产一成久久精品国产成人综合| 国产Av激情久久无码天堂| 青青久久精品国产免费看| 久久精品国产精品国产精品污| 97香蕉久久夜色精品国产| 久久久久亚洲精品无码网址 | 欧美久久天天综合香蕉伊| 91精品国产高清久久久久久io| 亚洲国产日韩综合久久精品| 亚洲天堂久久精品| 久久人人爽爽爽人久久久| 热久久视久久精品18| 久久精品中文字幕大胸| 久久精品国产欧美日韩| 久久久国产精品福利免费 | 色综合久久中文字幕综合网| 99久久精品无码一区二区毛片| 精品久久久久久久无码| 久久婷婷五月综合色高清| 伊人久久大香线焦AV综合影院 | 99久久婷婷免费国产综合精品| 2021国内精品久久久久久影院| 亚洲乱码日产精品a级毛片久久| 久久久这里有精品中文字幕| 久久人人爽人爽人人爽av|