C ++ Segfault追加,push_back和operator =或+ =

时间:2014-04-25 09:11:40

标签: c++ string segmentation-fault

我有一个非常简单的代码从文件读取并将字符追加到字符串并创建struct的数组。我使用init方法初始化字符串并使用push_back(char)附加到字符串但是两个初始化和push_back给了我段错误。 我想也许这是一个编译器问题,所以我下载了一个新的cygwin安装仍然没有工作。我尝试了MinGW,在MinGW我仍然有一个错误,但我无法看到它,因为调试时没有任何工作,在控制台中,printf没有显示,cin也没有工作,所以我无法进行初始化,只能在运行代码时看到错误。作为最后的结果我试过Visual Studio,它甚至没有编译我的代码,因为我没有恒定的数组大小。

typedef struct Employee_S {
    string ID, name, surname;
    int age;
    double salary;
} *Employee, Employee_t[1];

Employee employee_init() {
    Employee employee = (Employee) malloc(sizeof (Employee_t));
    if (employee == NULL) {
        printf("Error @ linked_arraylist_init: Cannot allocate memory. (Initialize Error)\n");
    } else {
        (employee->ID) = "";
        (employee->name) = "";
        (employee->surname) = "";
    }
    return employee;
}

我尝试使用+ =,append,=,push_back进行初始化,所有这些都给出了段错误

这是它创建的堆栈转储

Exception: STATUS_ACCESS_VIOLATION at rip=0057B1CAF9F
rax=3FFFFFFFFFFFFFF9 rbx=0000000600062BF0 rcx=0000000000000000
rdx=000000010040407A rsi=0000000000000000 rdi=000000000023A3E0
r8 =0000000000000000 r9 =000000010040407A r10=0000000000240000
r11=00000001004010E2 r12=0000000000000001 r13=0000000000000000
r14=0000000000000001 r15=0000000000000000
rbp=000000000023A340 rsp=000000000023A2C0
program=D:\Programming Stuff\asd\dist\Debug\Cygwin_4.x-Windows\asd.exe, pid 3320, thread main
cs=0033 ds=002B es=002B fs=0053 gs=002B ss=002B
Stack trace:
Frame        Function    Args
0000023A340  0057B1CAF9F (00000000000, 0000023AB2F, 10000000023A39E, 0000023AAD0)
0000023A340  0010040110E (0057B1C65FE, 00000000000, 00000000000, 0000023A8E0)
0000023A3D0  00100401783 (0000023A3F0, 0000023A800, 00100000020, 0000023A9FB)
0000023A460  0010040224E (00000000020, FF0700010302FF00, 0018004819A, 00000000000)
0000023AB90  0018004820B (00000000000, 00000000000, 00000000000, 00000000000)
00000000000  0018004611B (00000000000, 00000000000, 00000000000, 00000000000)
00000000000  00180046274 (00000000000, 00000000000, 00000000000, 00000000000)
00000000000  001004027A1 (00000000000, 00000000000, 00000000000, 00000000000)
00000000000  00100401010 (00000000000, 00000000000, 00000000000, 00000000000)
00000000000  7FFECA3416AD (00000000000, 00000000000, 00000000000, 00000000000)
00000000000  7FFECC494629 (00000000000, 00000000000, 00000000000, 00000000000)
End of stack trace

如果能在这件事上得到一些帮助,我会很高兴。

2 个答案:

答案 0 :(得分:1)

C malloc仅为employee分配内存,它不构造对象,因此像字符串这样的成员构造不正确。

在这种情况下你应该使用new/delete

Employee employee = new Employee_S();

也没有必要使用指针,代码更简单,更安全:

struct Employee_S {
    string ID;
        string name; 
        string surname;
    int age;
    double salary;
};

默认初始化Employee_S成员你只需编写

 Employee_S  es = {};

答案 1 :(得分:0)

您必须使用运算符new而不是C函数malloc。当您调用malloc时,未创建std::string类型的对象。函数malloc不调用对象的构造函数。

功能employee_init可以按以下方式查看

Employee employee_init() {
    Employee employee = new Employee_t();
    return employee;
}

此外,如果您打算使用Employee_S类型的数组,那么最好使用std::vector在这种情况下,该函数不是必需的。你可以简单地定义

std::vector<Employee_S> employee;