gpt4 book ai didi

c++ - std::string::assign(std::string const&) 中的段错误

转载 作者:太空宇宙 更新时间:2023-11-04 14:56:56 25 4
gpt4 key购买 nike

我在以下代码中遇到了指出的问题,我不知道它可能是什么原因造成的。我在发布问题之前进行了搜索,我了解到它可能超出了范围,比如对释放的内存位置的引用,但我无法自己找到它。感谢你们对我的帮助。

#include<iostream>
#include<string>
using namespace std;

class USR{
private:
string name;
public:
void setName(string name){
this->name = name;
}
string getName(){
return name;
}

};

class A{
private:
USR* * a;
public:
A(int size){
a = new USR*[size];
}
USR* getUser(){
return a[0];
}
};

int main(){
A test = A(5);
USR* u = test.getUser();
(*u).setName("test");
USR* u2 = test.getUser();
cout << (*u2).getName() << endl;
cout << (*u).getName() << endl;
}

最佳答案

问题是你分配了指针数组,但你从来没有为指针本身分配任何东西。

这为您提供了指针数组:

a = new USR*[size];

但是您从未为每个指针分配任何内容。

因此,它在这里崩溃了:

(*u).setName("test");

因为*u没有初始化


有两种方法可以解决这个问题:

  1. 为每个 USR 指针分配(并初始化)一些内容。
  2. 不要使用双指针。只需使用一个简单的 USR 对象数组即可。

我更喜欢后者,因为你所拥有的可能比它需要的更复杂。

像这样的东西可能会做你想做的事:

class A{
private:
USR *a;
public:
A(int size){
a = new USR[size];
}
USR* getUser(){
return &a[0];
}
};

不要忘记您还需要一个析构函数。

关于c++ - std::string::assign(std::string const&) 中的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8288535/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com