void Data::readstock(void) { ifstream file("D:\\price.txt"); string line; vector<Data> p; while (getline(file, line)) { stringstream ss(line); Data new_pe; stock new_stock; ss >> new_stock.num >> new_stock.name >> new_stock.price1 >> new_stock.price2 >> new_stock.price3; new_pe.s.push_back(new_stock); p.push_back(new_pe); } file.close(); for (int i = 0; i < p.size(); i++) { for (int j = 0; j < p[i].s.size(); j++) { p[i].s[j].print(); } } }为甚么向量下标超出范围
时间: 2024-03-31 15:38:38 浏览: 79
在这段代码中,向量p是一个存储了Data对象的向量,而每个Data对象中都只有一个股票对象stock。在读取price.txt文件时,每读取一行就创建一个新的Data对象,并将该行数据转换为股票对象stock,将该股票对象添加到新建的Data对象的向量s中,最后将新建的Data对象添加到p向量中。
在遍历p向量中的Data对象和其中的股票对象时,循环的上限应该是p.size()和p[i].s.size(),而不是p.size()-1和p[i].s.size()-1。因为向量的下标是从0开始的,所以当循环变量i或j等于p.size()或p[i].s.size()时,就超出了向量的范围。因此应该将for循环中的条件改为i < p.size()和j < p[i].s.size()。
相关问题
#include<iostream> using namespace std; #include<string> #include<sstream> #include <fstream> #include<vector> class pe {public: stock* s; }; class stock { public: string name; int num; double price1, price2, price3; void print() { cout << num << " " << name << " " << price1 <<" " << price2 << " " << price3 << endl; } }; /* ifstream fin("D:\\data.txt"); string line; Person *p=new Person[3]; while (getline(fin, line)) { int i = 0; stringstream ss(line); ss >> p[i].name >> p[i].age >> p[i].height; p[i].print(); i++; } fin.close(); return 0; */ int main() { string line; pe* p = new pe[3]; ifstream file("D:\\price.txt"); while (getline(file, line)) { int i = 0; int j = 0; stringstream ss(line); ss >>p[i].s[j].num >> p[i].s[j].name >> p[i].s[j].price1 >> p[i].s[j].price2 >> p[i].s[j].price3; p[i].s[j].print(); i++; j++; } file.close(); }以上代码如何修改问题
这段代码存在一些问题。首先,类 `pe` 中的成员变量 `s` 是一个指向 `stock` 类型的指针,但是在使用时并没有给它分配空间,因此在读取数据时会出现未定义的行为。其次,在读取数据时,`i` 和 `j` 变量的值在每次循环中都被重置为 0,因此无法正确地读取多个 `pe` 对象和多个 `stock` 对象。最后,在读取数据后并没有释放动态分配的内存,会导致内存泄漏。
针对这些问题,可以先将 `pe` 类中的成员变量 `s` 改为 `vector<stock>` 类型的容器,这样就不需要手动分配内存,同时可以动态增减元素。其次,在读取数据时需要使用两个循环变量 `i` 和 `j` 分别表示当前读取的 `pe` 对象和 `stock` 对象的下标。最后,在程序结束前需要手动释放动态分配的内存。
修改后的代码如下:
```
#include <iostream>
#include <fstream>
#include <sstream>
#include <string>
#include <vector>
using namespace std;
class stock {
public:
string name;
int num;
double price1, price2, price3;
void print()
{
cout << num << " " << name << " " << price1 << " " << price2 << " " << price3 << endl;
}
};
class pe {
public:
vector<stock> s;
};
int main()
{
ifstream file("D:\\price.txt");
string line;
vector<pe> p;
while (getline(file, line)) {
stringstream ss(line);
pe new_pe;
stock new_stock;
ss >> new_stock.num >> new_stock.name >> new_stock.price1 >> new_stock.price2 >> new_stock.price3;
new_pe.s.push_back(new_stock);
p.push_back(new_pe);
}
file.close();
for (int i = 0; i < p.size(); i++) {
for (int j = 0; j < p[i].s.size(); j++) {
p[i].s[j].print();
}
}
return 0;
}
```
请注意,这里的代码仅供参考,可能还存在其他问题。在实际编写代码时,请根据具体情况进行修改。
template<typename T> std::vector<T> parseCSV(const std::string &filename) { std::vector<T> data; std::ifstream file(filename); if (file) { std::string line; while (std::getline(file, line)) { T obj; obj.parseCSVRow(line); data.push_back(obj); } file.close(); } else { std::cout << "Failed to open the file: " << filename << std::endl; } return data; }
这是一个 C++ 的函数,用于解析 CSV 格式的文件,将其转化为指定类型的对象并存储在 vector 中。函数的模板参数 T 是表示要解析的对象类型,该类型需要定义 parseCSVRow 函数,用于解析一行 CSV 数据并初始化对象的属性。函数的参数 filename 表示要解析的文件名。函数首先打开指定的文件,然后逐行读取文件内容,创建对象并调用 parseCSVRow 函数进行解析,最后将对象存储在 vector 中并返回。如果文件打开失败,函数会输出错误信息并返回空 vector。
阅读全文