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