作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经编写了简单的内存分配器,但遇到了问题,我认为我没有像我想的那样访问内存元素:)并且我无法找出错误。输出方面再次存在两个问题,还有更多我不会意识到的问题。
问题 -1) while(block->next != NULL) 当到达下一个 block 时崩溃2) 在 free memptr->size 中为零。
我没有尝试研究内存对齐或碎片方面,目标是让一些简单的工作
#include <stdio.h>
#include <stdbool.h>
#define length 10000
char memory[length] = {0};
typedef struct MEMBLOCK
{
struct MEMBLOCK *next;
int size;
bool is_available;
}memblock;
int remain_memory = length;
memblock* ptrlastblock;
memblock* endOfBlock(memblock *block);
void* allocMemory(memblock *block, int size);
void* xmalloc(size_t size);
void myfree(void *ptr);
int main(void)
{
int *ptr = (int *)xmalloc(10);
if (ptr == NULL)
{
printf("memory allocation failed \n");
}
else
{
*ptr = 4;
}
// myfree(ptr);
int *ptr1 = (int *)xmalloc(10);
myfree(ptr1);
return 0;
}
void* xmalloc(size_t size)
{
memblock *block = (memblock*) memory; // point to head of memory region
return allocMemory(block, size);
}
void* allocMemory(memblock *block, int size)
{
if (remain_memory == length) // if no memory used allocate block
{
block->next = NULL;
block->is_available = false;
block->size = size;
ptrlastblock = endOfBlock(block); // point it to beginning of next block
remain_memory -= size;
return (void *)block + 1; // increment block so pointing to begining of memory post block
}
if(remain_memory > size)
{
while(block->next != NULL) // keep incrementing till you find
{ // last used chunk
block = block->next;
}
block = endOfBlock(block);
block->next = NULL;
block->size = size;
block->is_available = false;
remain_memory -= size;
return (void *)block + 1;
}
else
{
return NULL;
}
}
memblock* endOfBlock(memblock *block)
{
memblock* eofblock = (memblock*)((size_t)(block + 1) + (size_t)block->size);
return eofblock;
}
void myfree(void *ptr)
{
memblock *memptr = (memblock *)ptr - 1;
if (memptr->is_available == false)
{
memptr->is_available = true;
printf(" memory with pointer is %d \n", memptr->size);
remain_memory += memptr->size;
}
}
最佳答案
我认为问题在于:
return (void *)block + 1;
解释为:
((void *) block) + 1
因为强制转换的优先级高于加法。您可能会使用 *ptr = 4;
覆盖您的 memblock
结构。
[编辑]
我认为你应该按照尤金在评论中建议的去做:
return (void *) (block + 1)
关于c - 内存分配器 - 遍历内存时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37352246/
我是一名优秀的程序员,十分优秀!