错误的访问意味着我正在尝试访问不存在的内存我已经尝试并尝试为此类分配内存,但到处都失败了。我不知道错误实际来自哪里。它只告诉我我的setter方法是程序崩溃的时候。在 setFName() 方法中是发生错误的地方。但是在主要方法中它实际发生的地方。 护士.hpp
#ifndef Nurse_hpp
#define Nurse_hpp
#include <stdio.h>
#include <string>
#include <stdlib.h>
using namespace std;
class nurse{
private:
string firstName;
public:
nurse() {
firstName = "jim";
}
string getFName() {return firstName;}
void setFName(string fName) {firstName = fName;} // Thread 1: bad access 0x0
};
#endif /* Nurse_hpp */
这是实际发生错误的地方 main.cpp
#include <cstdint> // ::std::uint64_t type
#include <cstddef> // ::std::size_t type
#include <iostream>
#include <fstream>
#include <stdlib.h>
#include "nurseHolder.hpp"
using namespace std;
nurseHolder *l = new nurseHolder();
int main() {
return 0;
}
最后是导致问题的类 nurseHolder.hpp
#ifndef Nurses_hpp
#define Nurses_hpp
#include <stdio.h>
#include <vector>
#include <stdlib.h>
#include "Nurse.cpp"
using namespace std;
class nurseHolder{
private:
int nurse_cnt;
int nurse_cap;
vector<nurse> nurse_list;
public:
nurseHolder() {
nurse_cnt = 0;
nurse_cap = 10;
for(int i= 0; i < 11; i++){
nurse_list[i].setFName("na");
}
}
vector<nurse> &getNurseList() { return nurse_list;}
};
#endif /* Nurses_hpp */
如果代码太多,我尽量使这个紧凑。
以下是我为使代码正常工作所做的更改:
nurseHolder() {
nurse_cnt = 0;
nurse_cap = 10;
for(int i= 0; i < 11; i++){
nurse l;
nurse_list.pushback(l);
}
}
这是执行此操作的正确方法吗?
最佳答案
您的 vector nurse_list
的大小为 0。因此您不能使用 []
运算符来设置名称。
有两种方法可以更正此问题:
- 设置 vector 的初始大小并使用
[]
设置名称。 - 使用
push_back
向 vector 添加元素。
第一种方法。
nurse_list.resize(noOfTotalNurses).
nurse_list[i].setFName("name");
第二种方法。
nurse tNurse; //local nurse object
tNurse.setFName("name");
nurse_list.push_back(tNurse);
关于c++ - 为什么我的 setter 方法会产生错误的访问错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52586014/