SD卡的内容啃了好久,终于要搞定了,在这之前先学习内存管理的知识。
内存管理,是指软件运行时对内存资源的分配和使用,本次介绍的是分块式内存管理。
内存管理分为内存池和内存管理表,内存池是由n个大小相等的内存块组成,对应的内存管理表表示该内存块是否被占用(0:未被占用;非0:已被占用),且它的数值为连续被占用的内存块数;假如为5,表示包括该内存块在内,共有5个连续的内存块被占用。
它的分配方向是由顶层向底层分配,即先分配第n个内存块,接着第n-1个。
在申请下一个内存时,一定要释放前一次的内存,否则会丢失内存资源。
将src指向的n个字节复制到des指向的地址中;
往s指向的地址中写入count个的c;
内存表与内存池全部清零,并将就绪状态设为已就绪;
检索所有内存表,找出已占用的内存块,used+1;返回值为(已占用的内存块与总内存块的比值)*100;
在memx的内存中开辟一个size字节的内存空间;假如size为100;而块大小为32字节,则需要申请4个内存块才足够容纳100字节的数据。首先自顶向下地寻找空内存块,cmemb+1;一旦有内存块被占用,cmemb清0,重新寻找;直到找到4个连续的空内存块,或者未找到返回0xfffffff退出。如果找到了,还要对这个4个连续的内存管理表赋值,为4;并返回偏移量;offset为块的偏移量,它应该等于offset*每个块的字节大小。
将偏移地址之后的内存清零;
mymalloc()的返回值为偏移地址;
申请一个size大小的新内存,并把ptr指向地址的数据复制到新申请的内存中,并返回新内存的首地址。