У меня есть произвольно длинная строка целых чисел (или значений с плавающей запятой), разделенных запятыми в файле:
1,2,3,4,5,6,7,8,2,3,4,5,6,7,8,9,3,... (can go upto >100 MB)
Теперь я должен прочитать эти значения и сохранить их в массиве.
Моя текущая реализация выглядит так:
float* read_line(int dimension)
{
float *values = new float[dimension*dimension]; // a line will have dimension^2 values
std::string line;
char *token = NULL, *buffer = NULL, *tmp = NULL;
int count = 0;
getline(file, line);
buffer = new char[line.length() + 1];
strcpy(buffer, line.c_str());
for( token = strtok(buffer, ","); token != NULL; token = strtok(NULL, ","), count++ )
{
values[count] = strtod(token, &tmp);
}
delete buffer;
return values;
}
Мне не нравится эта реализация, потому что:
- Используя
ifstream
, весь файл загружается в память, и
затем клонируется в float []
- Существует ненужное дублирование (преобразование из
std::string
в const char*
)
Как оптимизировать использование памяти?
Спасибо!