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

各位大佬,这是我在静态链表程序里写的模拟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】去哪里了呢?

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问