• <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 工作機制

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

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

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

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

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

            評論

            # re: C語言 malloc 工作機制  回復  更多評論   

            學習了
            2013-03-29 11:15 | 曦花
            久久久久久亚洲精品无码| 亚洲精品乱码久久久久久蜜桃图片| 久久精品人人做人人爽电影| 色欲av伊人久久大香线蕉影院| 国产精品亚洲综合久久| 99精品久久精品一区二区| 色综合久久久久综合99| 97久久久精品综合88久久| 伊人久久综合热线大杳蕉下载| 免费无码国产欧美久久18| 久久久精品国产sm调教网站| 日韩精品久久无码中文字幕| 国产亚洲美女精品久久久| 久久国产精品免费一区| 久久久久无码精品国产不卡| 久久影视国产亚洲| 一级女性全黄久久生活片免费| 中文精品99久久国产| 天天综合久久久网| 久久免费美女视频| 亚洲国产精品久久久天堂| 久久亚洲2019中文字幕| 国产午夜精品理论片久久 | 久久亚洲AV成人无码软件| 99久久www免费人成精品| 久久91综合国产91久久精品| 久久久久综合网久久| 99国产精品久久| 久久精品人人做人人爽电影| 久久人妻少妇嫩草AV无码专区| 久久狠狠爱亚洲综合影院 | 亚洲中文久久精品无码| 久久天堂AV综合合色蜜桃网| 综合久久国产九一剧情麻豆| 久久精品国产男包| 日韩精品无码久久久久久| 久久久久人妻一区二区三区vr| 精品久久亚洲中文无码| 亚洲AV无码久久| 久久777国产线看观看精品| 国产成人AV综合久久|