Reputation: 107
I want 41 output files to use in my project to write text on them. first create a string array list
to name those output files then I tried to define an array of ofstream objects and use list
to name them, but I get this error that 'outfile' cannot be used as a function
. Below is my code:
#include <sstream>
#include <string>
#include <iostream>
#include <fstream>
using namespace std ;
int main ()
{
string list [41];
int i=1;
ofstream *outFile = new ofstream [41];
for (i=1;i<=41 ;i++)
{
stringstream sstm;
sstm << "subnode" << i;
list[i] = sstm.str();
}
for (i=0;i<=41;i++)
outFile[i] (list[i].c_str());
i=1;
for (i=1;i<=41;i++)
cout << list[i] << endl;
return 0;
}
Upvotes: 4
Views: 12441
Reputation: 392931
See below for the following fixes:
new
unless you have to (you were leaking all files and not properly destructing them will lead to lost data; ofstreams might not be flushed if you don't close them properly, and the pending output buffer will be lost).open(...)
on a default-constructed ofstream
to open a fileusing namespace std;
(not changed below)stringstream
. This is is good practicefor (int i = ....
). This prevents surprises from i
having excess scope.#include <sstream>
#include <string>
#include <iostream>
#include <fstream>
using namespace std;
int main ()
{
ofstream outFile[41];
stringstream sstm;
for (int i=0;i<41 ;i++)
{
sstm.str("");
sstm << "subnode" << i;
outFile[i].open(sstm.str());
}
for (auto& o:outFile)
cout << std::boolalpha << o.good() << endl;
}
Upvotes: 7
Reputation: 70929
You can not call the constructor as you do. Try calling outFile[i].open(list[i].c_str())
. Note the 'open'.
Upvotes: 1