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

            隨筆 - 25, 文章 - 0, 評論 - 6, 引用 - 0
            數(shù)據(jù)加載中……

            C語言 malloc 工作機(jī)制

            void *malloc (size_t stSize);
            該函數(shù)在內(nèi)存的動態(tài)存儲區(qū)中分配 stSize 連續(xù)空間,返回值是一個指向所分配的連續(xù)存儲域的起始地址的指針。

            void free(void *firstbyte);
            如果給定一個由先前的 malloc 返回的指針,那么該函數(shù)會將分配的空間歸還給進(jìn)程的“空閑空間”。

            malloc 工作機(jī)制:
            malloc函數(shù)的實質(zhì)體現(xiàn)在,它有一個將可用的內(nèi)存塊連接為一個長長的列表的所謂空閑鏈表。調(diào)用malloc函數(shù)時,它沿連接表尋找一個大到足以滿足用戶請求所需要的內(nèi)存塊。然后,將該內(nèi)存塊一分為二(一塊的大小與用戶請求的大小相等,另一塊的大小就是剩下的字節(jié))。接下來,將分配給用戶的那塊內(nèi)存?zhèn)鹘o用戶,并將剩下的那塊(如果有的話)返回到連接表上。調(diào)用free函數(shù)時,它將用戶釋放的內(nèi)存塊連接到空閑鏈上。到最后,空閑鏈會被切成很多的小內(nèi)存片段,如果這時用戶申請一個大的內(nèi)存片段,那么空閑鏈上可能沒有可以滿足用戶要求的片段了。于是,malloc函數(shù)請求延時,并開始在空閑鏈上翻箱倒柜地檢查各內(nèi)存片段,對它們進(jìn)行整理,將相鄰的小空閑塊合并成較大的內(nèi)存塊。

            參考:http://www.cnblogs.com/xkfz007/articles/2729027.html

            posted on 2013-03-19 17:08 chenjt3533 閱讀(342) 評論(1)  編輯 收藏 引用 所屬分類: C/C++

            評論

            # re: C語言 malloc 工作機(jī)制  回復(fù)  更多評論   

            學(xué)習(xí)了
            2013-03-29 11:15 | 曦花
            久久久久久精品免费免费自慰| 久久精品国产精品青草| 日本久久中文字幕| 久久人人爽人人爽人人AV| 亚洲国产精品久久久久网站| 蜜臀久久99精品久久久久久| 亚洲中文字幕无码久久综合网| 国产精品久久波多野结衣| 亚洲国产综合久久天堂| 狠狠色丁香久久婷婷综合五月| 久久精品无码一区二区三区免费 | 久久精品人人做人人爽97| 国产成人精品久久亚洲| 男女久久久国产一区二区三区| 国产激情久久久久影院老熟女免费| 亚洲国产天堂久久久久久| 亚洲国产二区三区久久| 亚洲级αV无码毛片久久精品| 久久久久久国产精品美女| 久久99精品国产一区二区三区| 伊人久久大香线蕉av一区| 亚洲午夜久久久| 午夜精品久久久久成人| 青青久久精品国产免费看| 亚洲一本综合久久| 久久香蕉综合色一综合色88| 久久免费的精品国产V∧| 伊人久久大香线蕉AV色婷婷色| 亚洲国产成人久久一区WWW| 日韩精品无码久久一区二区三| 一本久久久久久久| 国产2021久久精品| 曰曰摸天天摸人人看久久久| 狠狠色丁香久久综合五月| 91精品国产高清久久久久久io| 久久人妻少妇嫩草AV无码专区| 亚洲国产欧洲综合997久久| 亚洲午夜久久久影院伊人| 久久99国产综合精品| 久久精品国产99国产精品澳门| 99热精品久久只有精品|