Cheesberry 2022-09-05 06:16 采纳率: 100%
浏览 32
已结题

在函数内new一个空间的时候报错了

问题遇到的现象和发生背景

写一个顺序表,在函数内new一个数组的时候报错了,试了好久不知道为什么

问题相关代码,请勿粘贴截图

class List{
public:
int* data;
int lenth;

List* InitList(List* &L); // 构造一个空的顺序表
void Destory(List* &L);

};

List* List::InitList(List* &L){ // 构造一个空的顺序表
L->data = new int[100]; // 为顺序表分配空间
if(!L){
cerr << "内存分配失败!" << endl;
}
return L;
}

void List::Destory(List* &L){
delete[] L->data;
}

int main()
{
List *L1;
L1 = L1->InitList(L1);
L1->Destory(L1);
return 0;
}

运行结果及报错内容

运行之后这句话报错了,
L->data = new int[100]; // 为顺序表分配空间
报错信息是
0x00007FF6276C24D6 处(位于 顺序表实现线性表合并.exe 中)引发的异常: 0xC0000005: 读取位置 0xn个F 时发生访问冲突。

我的解答思路和尝试过的方法

然而我先声明List类的实例,再用指针指向它程序就可以正常运行。
int main()
{
List L1;
List *p;
p = &L1;
p = p->InitList(p);
p->Destory(p);
return 0;
}

我想要达到的结果

原程序能运行
求解答,实在不理解

展开全部

  • 写回答

2条回答 默认 最新

  • 快乐鹦鹉 2022-09-05 06:22
    关注

    List *L1;
    L1 = L1->InitList(L1);
    指针还没分配空间,不能操作其属性
    函数也不能这么写啊,List本身就代表顺序表对象了,初始化为空就不需要再传递一个类指针

    class List{
    public:
    int* data;
    int lenth;
    
    void InitList(); // 构造一个空的顺序表
    void Destory();
    };
    
    void List::InitList(){ // 构造一个空的顺序表
    data = new int[100]; // 为顺序表分配空间
    if(data == NULL){
    cerr << "内存分配失败!" << endl;
    }
    length = 0;
    }
    
    void List::Destory(){
      if(data == NULL)
            return ;
    delete[] data;
      data = NULL;
      length = 0;
    }
    
    int main()
    {
    List L;
    L.InitList();
    L.Destory();
    return 0;
    }
    
    

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
    Cheesberry 2022-09-05 06:34

    啊对哦,感谢!!

    回复
查看更多回答(1条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 9月12日
  • 已采纳回答 9月5日
  • 创建了问题 9月5日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部