• <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 閱讀(364) 評論(1)  編輯 收藏 引用 所屬分類: C/C++

            評論

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

            學(xué)習(xí)了
            2013-03-29 11:15 | 曦花
            91久久精品视频| 久久精品国产亚洲av水果派| 99久久人人爽亚洲精品美女| 一级做a爰片久久毛片16| 日本加勒比久久精品| 婷婷久久综合九色综合98| 四虎国产精品成人免费久久| 久久综合给合久久狠狠狠97色69 | 久久免费精品一区二区| 久久亚洲AV永久无码精品| 久久精品成人免费网站| 热re99久久精品国99热| 久久久久国产视频电影| 狠狠人妻久久久久久综合| 夜夜亚洲天天久久| 久久精品国产亚洲AV蜜臀色欲 | 99久久777色| 久久久九九有精品国产| 亚洲精品乱码久久久久久蜜桃| 久久有码中文字幕| 99久久精品国产免看国产一区| 久久精品国产2020| 亚洲国产高清精品线久久| 国产福利电影一区二区三区久久老子无码午夜伦不 | 欧美亚洲日本久久精品| 久久精品无码一区二区三区| 午夜精品久久久久久99热| 97久久久精品综合88久久| 伊人久久大香线蕉综合影院首页| 伊人久久大香线蕉AV色婷婷色| 欧美午夜A∨大片久久 | 久久国产精品成人片免费| 久久亚洲国产精品成人AV秋霞 | 国产美女久久精品香蕉69| 国产综合精品久久亚洲| 久久精品国产亚洲综合色| 精品久久久噜噜噜久久久| 久久A级毛片免费观看| 国产精品免费看久久久| 99久久人妻无码精品系列| 潮喷大喷水系列无码久久精品|