首页 > 为什么顺序表这样申请空间,程序会崩溃

为什么顺序表这样申请空间,程序会崩溃

是在下面代码中的这一行崩溃的:

l -> data = (int *)malloc(sizeof(int) * n);

整个代码如下:

typedef struct
{
    int *data;
    int last;
}List;
List *Create(int n)
{
    List *l;
    l -> data = (int *)malloc(sizeof(int) * n);
    l -> last = -1;
    return l;
}

因为 l 只是一个指针,并没有为其分配指向的内存空间,所以相应成员 data last 都不存在,对其赋值是错误的。

List *l = (List *)malloc(sizeof(List)); 

把 l 初始化,这样既可。

【热门文章】
【热门文章】