我目前正在使用如下所示的静态结构:
typedef struct chunk_tag {
struct chunk_tag *next;
struct chunk_tag *prev;
int size;
} chunk_t;
chunk_t *morecore(int new_bytes);
它有大小,下一个和上一个。
就在这下面,我有以下几行:
static chunk_t * First = NULL;
static chunk_t * Rover = NULL;
然后它进入如下所示的函数:
void *Mem_alloc(int nbytes)
{
chunk_t *p = NULL;
//chunk_t *q = NULL;
chunk_t *best;
int blocks;
blocks = nbytes/sizeof(chunk_t);
if(nbytes % sizeof(chunk_t) != 0)
{
blocks++;
}
if(First == NULL)//means new page
{
First = morecore(PAGESIZE);
if(First == NULL)
{
return p;
}
First->size = 0;
Rover->size = PAGESIZE / sizeof(chunk_t)-1; //this line segfaults
First->prev = (First + 1);
First->next = (First + 1);
Rover = First->next;
Rover->prev = First;
Rover->next = First;
requests++;
}
正如你所看到的,我试图将一些东西放入流动站大小。上面的行将零放入第一个大小。但是当流动站的大小应该等于那个小方程时,它就会出现段错误。我知道这不是方程式,因为当我将它放入第一个尺寸时,它可以正常工作。即使我尝试将 0 放入流动站大小,它也会出现故障。
有什么想法吗?