1

首先,我要问的可能吗?

我目前有一个带有一个成员方法(读取)的程序,它在一个成员方法中从本地 .txt 文件中读取字符串,并将相同的数据输出到控制台。现在,我无法对数组的内容做任何事情,但是我需要在 Write 方法和代码中的任何其他地方使用数据。我使用了动态 C 样式数组,因为这是我所需要的,不允许使用向量等。一个解决方案或任何大方向都会很棒!

我的结构由一个 Main.cpp、一个 ArrayStorage.cpp 类定义和一个 ArrayStorage.h 头文件组成。

我的代码如下:

数组存储.cpp

#include <fstream>
#include <iostream>
#include <ostream>
#include <string>
#include "ArrayStorage.h"
using namespace std;


void ArrayStorage::read(ifstream &fin1)
{
    int index = 0;
    int arrayLength = 0;
    string firstWord;

    if(fin1.is_open())
        {
            fin1 >> firstWord;
            fin1 >> arrayLength;

            string* arrayOfWords;
            arrayOfWords = new string[arrayLength];

            while(!fin1.eof())
            {
                fin1 >> arrayOfWords[index];
                cout << arrayOfWords[index];
                cout << "\n";
                index++;
            }

            delete [] arrayOfWords;

            fin1.close();
        }
}

void ArrayStorage::write(ofstream &out1)
{
    //fout.close();
}

数组存储.h

#include <fstream> // Reading/Writing from file requires this standard library.
#include <iostream> // Needed for cin and cout
#include <ostream> // Needed for outputting to output file
#include <string> // Needed for string values
using namespace std;

#pragma once

class ArrayStorage
{
private:



public:

    void read(ifstream &fin1); //reads data from a file
    void write(ofstream &out1); //output data to an output stream(ostream)
    bool exists(); //return true or false depending whether or not a given word exists
    void stdExists(); //^^ use either std::count() or std::find() inside here


};

主文件

#include <fstream>
#include <iostream>
using namespace std;

#include "ArrayStorage.h"
#include "LinkedListStorage.h"


int main(int argc, char **argv) {

string find = "pixel";

ifstream fin1("ACW2_data.txt");
ofstream out1("1-In-SortedRead.txt");

if(!fin1.is_open()) 
{
    cout << "FAIL" << endl;
    return 1;
}

ArrayStorage arrayStorage1;

// read in values into data structure
arrayStorage1.read(fin1);

// output values in data structure to file
arrayStorage1.write(out1);

fin1.close();
out1.close();
return(0);
}
4

1 回答 1

0

正如 AnatolyS 所说,你应该让 arrayOfWords 成为你类的私有成员变量。

然后为了确保没有内存泄漏或访问冲突错误,我建议以下内容:

  1. 在构造函数中将其初始化为 NULL

    void ArrayStorage::ArrayStorage()
        : arrayOfWords(NULL)
    {}
    
  2. 如果不为 NULL,则在析构函数中将其删除

    void ArrayStorage::~ArrayStorage()
    {
        if (arrayOfWords)
            delete []arrayOfWords;
    }
    
  3. 读取新文件时,请删除旧数组,以防同一个类被用于读取多个文件(假设这是您想要的行为)。

    if (arrayOfWords)
        delete []arrayOfWords;
    arrayOfWords = new string[arrayLength];
    
  4. 在您的“写入”函数(或访问数组的任何其他函数)中,在尝试使用它之前检查它是否不是 NULL。

您可以做的另一件事是检查“new”运算符是否不返回 NULL 指针(如果内存不足,可能会发生这种情况)。

这个例子说明了为什么像 vector 这样的类如此有用,因为它们为你处理了很多这些分配/释放的细节。

于 2013-05-16T20:13:50.813 回答