开发者社区 问答 正文

为什么顺序表这样申请空间?

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

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;
}

展开
收起
杨冬芳 2016-05-30 16:25:52 2242 分享 版权
1 条回答
写回答
取消 提交回答
  • IT从业

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

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

    把 l 初始化,这样既可。

    2019-07-17 19:20:43
    赞同 展开评论
问答地址: