• <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 | 曦花
            国产精品免费久久久久电影网| 伊人久久大香线蕉av不变影院 | 色综合久久久久无码专区| 亚洲国产成人久久精品99| 老男人久久青草av高清| 99久久精品影院老鸭窝| 久久亚洲精品国产精品婷婷 | 色婷婷久久综合中文久久一本| 性欧美大战久久久久久久久| 久久精品无码av| 精品久久香蕉国产线看观看亚洲| 亚洲国产成人精品女人久久久 | 亚洲午夜福利精品久久| 国产成人久久AV免费| 伊人久久久AV老熟妇色| 亚洲国产精品成人久久蜜臀| 99久久婷婷国产一区二区| 色妞色综合久久夜夜| 伊人久久大香线蕉AV一区二区 | 欧美国产成人久久精品| 久久国产视频网| 国产L精品国产亚洲区久久| 国产精品久久久久久| 久久精品人人做人人爽电影蜜月| 久久91精品国产91| 免费一级欧美大片久久网| 久久久久国产日韩精品网站| 国产精品一区二区久久精品无码| 精品久久香蕉国产线看观看亚洲 | 中文字幕成人精品久久不卡| 国产亚洲美女精品久久久久狼| 国产精品无码久久综合| 欧美一区二区三区久久综合| 无码精品久久久久久人妻中字| 无码任你躁久久久久久老妇App| 亚洲精品第一综合99久久| 日韩欧美亚洲综合久久影院Ds| 青青久久精品国产免费看| 亚洲欧美久久久久9999| 久久人人爽人人爽人人片AV高清 | 国产精品久久久久影院嫩草|