如果有一个非常重要的原因需要对数组执行此操作,请使用std::new,如下所示:
#include <iostream>
#include <string>
#include <vector>
#include <fstream>
using namespace std;
int reading(string** str_array, int& size, string filename) {
ifstream infile(filename.c_str());
if(!infile) {
cerr << "Unable to access file!\n";
return -1;
}
int n = 0;
infile >> size;
try{
*str_array = new string[size];
string str;
for (; n < size && infile; ++n) {
infile >> str;
(*str_array)[n] = str;
}
if (n != size)
cerr << "ERROR, read less than " << size << " strings!!\n\n";
} catch(bad_alloc& exc) {
return -2;
}
return 0;
}
int main() {
string* str_array = NULL;
int size;
if(reading(&str_array, size, "test.txt")) {
cerr << "Din't read file, exiting...\n";
return -1;
}
for(int i = 0; i < size; ++i)
cout << str_array[i] << endl;
delete [] str_array; // DO NOT FORGET TO FREE YOUR MEMORY
str_array = NULL;
return 0;
}
输出:
C02QT2UBFVH6-lm:~ gsamaras$ ./a.out
String
String2
String3
但是,您在 c++ 中并且没有为此使用 std::vector?
看看它是多么简单:
#include <iostream>
#include <vector>
#include <fstream>
using namespace std;
int reading(vector<string>& v, string filename) {
ifstream infile(filename.c_str());
if(!infile) {
cerr << "Unable to access file!\n";
return -1;
}
int N = -1, n = 0;
infile >> N;
string str;
for (; n < N && infile; ++n) {
infile >> str;
v.push_back(str);
}
if (n != N)
cerr << "ERROR, read less than " << N << " strings!!\n\n";
return 0;
}
int main() {
vector<string> v;
if(reading(v, "test.txt")) {
cerr << "Din't read file, exiting...\n";
return -1;
}
for(size_t i = 0; i < v.size(); ++i)
cout << v[i] << "\n";
return 0;
}
输出:
C02QT2UBFVH6-lm:~ gsamaras$ ./a.out
String
String2
String3
编辑:
我们必须传递一个指向我们想要修改的指针(即string*),否则我们应用的更改不会发生。自己测试一下,将string* 作为参数传递而不是string**,修改函数的主体,然后会发生什么。
为了理解这个想法,假设我们想要写入指针,新地址,new 给了我们并保存了请求的内存。我们确实在函数中写入了该地址,但是当函数终止时,我们希望更改是持久的。以我的Functions in C 为例。