繁体   English   中英

std :: string :: assign(std :: string const&)中的分段错误

[英]Segmentation fault in std::string::assign(std::string const&)

我有以下代码所示的问题,我不知道这可能是什么原因。 我在发布问题之前进行了搜索,然后得知它可能超出了范围,例如对释放的内存位置的引用,但我自己找不到。 感谢你们对我的帮助。

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

不要忘记,您也将需要一个析构函数。

您的方法getUser返回一个未初始化的指针( A的构造函数创建一个未初始化的指针数组)。 您看到的错误是取消引用该方法返回的未初始化指针的结果。

您仅创建一个新的USR*数组,而不是USR对象的数组。 访问指针

USR* u = test.getUser();

将为您提供一个统一的指针。 呼唤

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

因此将出现段错误。

您初始化了USR*的数组,但尚未初始化单个USR*对象。

由于您已经声明了USR的2D数组,所以我认为您对用户名数组必须具有Array的要求,尽管这对我来说很奇怪,为什么您不能简单地使用USR * userArray;

无论如何,如果要使用户名数组的数组起作用,则需要按如下所示修改类A:

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM