• <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)存的動(dòng)態(tài)存儲區(qū)中分配 stSize 連續(xù)空間,返回值是一個(gè)指向所分配的連續(xù)存儲域的起始地址的指針。

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

            malloc 工作機(jī)制:
            malloc函數(shù)的實(shí)質(zhì)體現(xiàn)在,它有一個(gè)將可用的內(nèi)存塊連接為一個(gè)長長的列表的所謂空閑鏈表。調(diào)用malloc函數(shù)時(shí),它沿連接表尋找一個(gè)大到足以滿足用戶請求所需要的內(nèi)存塊。然后,將該內(nèi)存塊一分為二(一塊的大小與用戶請求的大小相等,另一塊的大小就是剩下的字節(jié))。接下來,將分配給用戶的那塊內(nèi)存?zhèn)鹘o用戶,并將剩下的那塊(如果有的話)返回到連接表上。調(diào)用free函數(shù)時(shí),它將用戶釋放的內(nèi)存塊連接到空閑鏈上。到最后,空閑鏈會(huì)被切成很多的小內(nèi)存片段,如果這時(shí)用戶申請一個(gè)大的內(nèi)存片段,那么空閑鏈上可能沒有可以滿足用戶要求的片段了。于是,malloc函數(shù)請求延時(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 | 曦花
            久久毛片免费看一区二区三区| 久久亚洲精品国产亚洲老地址| 色偷偷888欧美精品久久久| 久久精品亚洲福利| 久久婷婷五月综合97色| 久久久久国产一区二区三区| 97久久国产综合精品女不卡 | 亚洲国产精品狼友中文久久久| 亚洲国产精品18久久久久久| 久久亚洲色一区二区三区| 狠狠色狠狠色综合久久| 久久精品国产亚洲精品| 大伊人青草狠狠久久| 久久久久久久精品妇女99| 久久国产V一级毛多内射| 99国产精品久久| 久久人人爽人人爽人人片AV不| 亚洲а∨天堂久久精品9966| 99久久亚洲综合精品成人| 久久99国产综合精品| 久久亚洲精精品中文字幕| 久久综合精品国产一区二区三区| 久久久综合九色合综国产| 丰满少妇高潮惨叫久久久| 久久人人爽人人爽人人片AV不 | 久久久久99精品成人片欧美| 亚洲国产成人久久综合野外| 久久亚洲AV无码西西人体| 99久久精品无码一区二区毛片 | 26uuu久久五月天| 久久99久久99小草精品免视看| 午夜天堂av天堂久久久| 偷窥少妇久久久久久久久| 亚洲国产香蕉人人爽成AV片久久| 久久精品中文字幕第23页| 亚洲精品国产成人99久久| 99久久国产主播综合精品| 精品久久人人妻人人做精品| 久久久国产精品| 中文成人久久久久影院免费观看| 综合久久精品色|