久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

標(biāo)題: malloc函數(shù)從FAT32文件擴(kuò)展到內(nèi)存 [打印本頁(yè)]

作者: 51黑黑黑    時(shí)間: 2016-2-23 23:23
標(biāo)題: malloc函數(shù)從FAT32文件擴(kuò)展到內(nèi)存
       malloc的全稱(chēng)是memoryallocation,中文叫動(dòng)態(tài)內(nèi)存分配,當(dāng)無(wú)法知道內(nèi)存具體位置的時(shí)候,想要綁定真正的內(nèi)存空間,就需要用到動(dòng)態(tài)的分配內(nèi)存。
      malloc 向系統(tǒng)申請(qǐng)分配指定size個(gè)字節(jié)的內(nèi)存空間。返回類(lèi)型是 void* 類(lèi)型。void*表示未確定類(lèi)型的指針。C/C++規(guī)定,void*類(lèi)型可以強(qiáng)制轉(zhuǎn)換為任何其它類(lèi)型的指針。​
​內(nèi)存空間是連續(xù)的。
001--002--003--004……00n
內(nèi)存應(yīng)該支持這樣一個(gè)結(jié)構(gòu):鏈表,連接空閑內(nèi)存空間​
​​
調(diào)用malloc函數(shù):
1:根據(jù)內(nèi)存塊的空閑鏈表尋找一個(gè)大到足以滿(mǎn)足用戶(hù)請(qǐng)求所需要的內(nèi)存塊。(為什么是大于呢?哥哥,沒(méi)有那么巧合的事,要100字節(jié),就有一個(gè)100字節(jié)的空間等著你?赡苁150字節(jié)的空間等著你)
2:將該內(nèi)存塊一分為二(一塊的大小與用戶(hù)請(qǐng)求的大小相等(100字節(jié)大小),另一塊的大小就是剩下的字節(jié)(50字節(jié)))。
3:將100字節(jié)大小的內(nèi)存地址傳給用戶(hù),
4:并將剩下的50字節(jié)內(nèi)存塊(如果有的話(huà))返回到空閑鏈表上。


調(diào)用free函數(shù):
將用戶(hù)釋放的內(nèi)存塊連接到空閑鏈上。

     久而久之,空閑鏈會(huì)被切成很多的小內(nèi)存片段(這邊50字節(jié),那邊30個(gè)字節(jié)……),如果這時(shí)用戶(hù)申請(qǐng)一個(gè)比較大的內(nèi)存片段,那么空閑鏈上可能沒(méi)有可以滿(mǎn)足用戶(hù)要求的片段了。
     那要怎么辦呢?malloc函數(shù)請(qǐng)求延時(shí),開(kāi)始在空閑鏈上翻箱倒柜地檢查各內(nèi)存片段,對(duì)它們進(jìn)行整理,將相鄰的小空閑塊合并成較大的內(nèi)存塊。如果無(wú)法獲得符合要求的內(nèi)存塊,malloc函數(shù)會(huì)返回NULL指針,表明分配內(nèi)存空間失敗。
因此在調(diào)用malloc動(dòng)態(tài)申請(qǐng)內(nèi)存塊時(shí),一定要進(jìn)行返回值的判斷。






歡迎光臨 (http://www.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 欧美成人综合 | 九七午夜剧场福利写真 | 黄色片a级 | 精产国产伦理一二三区 | 三级高清 | 日韩国产欧美在线观看 | 青娱乐av | 99久久婷婷国产综合精品首页 | 在线一区二区三区 | 久久久久国产一级毛片高清网站 | 国产精品视频不卡 | 亚洲成人午夜电影 | 99久久国产精 | 91在线| 国产高清视频在线 | 91免费看片| 日韩精品成人av | 久久中文字幕一区 | 成人精品一区二区三区中文字幕 | 免费不卡视频 | 亚洲第一福利网 | 成人不卡 | 日本精品一区二区在线观看 | 日本又色又爽又黄又高潮 | 亚洲视频免费观看 | 在线观看国产三级 | 在线国产一区二区三区 | 伊人久久综合 | 欧美日韩精品免费观看 | 久久精品视频在线播放 | 亚洲天天 | 欧美激情精品久久久久久 | 日韩午夜精品 | 亚洲一二三区在线观看 | 男女久久久 | 欧美三级免费观看 | 日韩a v在线免费观看 | 九九伊人sl水蜜桃色推荐 | 伊人久久大香线 | 午夜男人视频 | 欧洲成人免费视频 |