开发者社区> 问答> 正文

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

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

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 2142 0
1 条回答
写回答
取消 提交回答
  • IT从业

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

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

    把 l 初始化,这样既可。

    2019-07-17 19:20:43
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载