|
|||||||||||
| 技術(shù)交流 | 電路欣賞 | 工控天地 | 數(shù)字廣電 | 通信技術(shù) | 電源技術(shù) | 測控之家 | EMC技術(shù) | ARM技術(shù) | EDA技術(shù) | PCB技術(shù) | 嵌入式系統(tǒng) 驅(qū)動編程 | 集成電路 | 器件替換 | 模擬技術(shù) | 新手園地 | 單 片 機 | DSP技術(shù) | MCU技術(shù) | IC 設(shè)計 | IC 產(chǎn)業(yè) | CAN-bus/DeviceNe |
請教一段代碼理解 |
| 作者:numen_he 欄目:通信技術(shù) |
struct mem { mem_size_t next, prev; #if MEM_ALIGNMENT == 1 u8_t used; #elif MEM_ALIGNMENT == 2 u16_t used; #elif MEM_ALIGNMENT == 4 u32_t used; #elif MEM_ALIGNMENT == 8 u64_t used; #else #error "unhandled MEM_ALIGNMENT size" #endif /* MEM_ALIGNMENT */ }; static struct mem *ram_end; static u8_t ram[MEM_SIZE + sizeof(struct mem) + MEM_ALIGNMENT]; static struct mem *lfree; /* pointer to the lowest free block */ static void plug_holes(struct mem *mem) { struct mem *nmem; struct mem *pmem; /* plug hole forward */ nmem = (struct mem *)&ram[mem->next]; if (mem != nmem && nmem->used == 0 && (u8_t *)nmem != (u8_t *)ram_end) { if (lfree == nmem) { lfree = mem; } mem->next = nmem->next; ((struct mem *)&ram[nmem->next])->prev = (u8_t *)mem - ram; } /* plug hole backward */ pmem = (struct mem *)&ram[mem->prev]; if (pmem != mem && pmem->used == 0) { if (lfree == mem) { lfree = pmem; } pmem->next = mem->next; ((struct mem *)&ram[mem->next])->prev = (u8_t *)pmem - ram; } } 這段代碼我看了好幾遍,還是一頭霧水,不知道他想干嘛,有高手能指點一下嗎?不勝感激 |
| 2樓: | >>參與討論 |
| 作者: huyong2006 于 2006/4/16 15:01:00 發(fā)布:
就看懂了一點點 好象是分配存儲區(qū)的吧,我只看懂了前面的#Define,那是內(nèi)存對齊問題 后面的應(yīng)該是具體分配的算法,可以小弟也不怎么精通,就這么點認識。 |
|
|
|
| 免費注冊為維庫電子開發(fā)網(wǎng)會員,參與電子工程師社區(qū)討論,點此進入 |
Copyright © 1998-2006 m.58mhw.cn 浙ICP證030469號 |