gpt4 book ai didi

c - 内存分配器 - 遍历内存时出现问题

转载 作者:行者123 更新时间:2023-11-30 19:12:19 24 4
gpt4 key购买 nike

我已经编写了简单的内存分配器,但遇到了问题,我认为我没有像我想的那样访问内存元素:)并且我无法找出错误。输出方面再次存在两个问题,还有更多我不会意识到的问题。

问题 -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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com