Y_csgoto 2019-05-22 22:38 采纳率: 57.1%
浏览 186

关于静态链表的动态分配函数

各位大佬,这是我在静态链表程序里写的模拟malloc程序

int Malloc(int Long)//动态分配空间函数
{int num=1;
while(((Stalistpool[num]).real==1)&&(num<=maxsize+1))//当该处的结构体未被调用,且位置在最大范围限制之内
num++;
Stalistpool[num].real=1;
if(num!=maxsize+2)

return num;
else
printf("分配内存失败");
return 0;

}

结构体的定义是

typedef struct list
{
Date key;
couser next;
int real;//是否被引用的判定
}Stalist;
Stalist Stalistpool[maxsize+1]={0,0,0};//储存池 

我把Stalistpool【0】作为保留位,从Stalistpool【1】开始分配空间,按照程序,第一次分配的时候,num输出时应该等于1,但是实际上是等于2,那么Stalistpool【1】去哪里了呢?

  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2022-09-09 16:24
    关注
    不知道你这个问题是否已经解决, 如果还没有解决的话:

    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 以帮助更多的人 ^-^
    评论

报告相同问题?