C/C++ Help
 
Forums: » Register « |  User CP |  Games |  Calendar |  Members |  FAQs |  Sitemap |  Support | 
 
User Name:
Password:
Remember me
 
Go Back   Dev Articles Community ForumsProgrammingC/C++ Help

Reply
Add This Thread To:
  Del.icio.us   Digg   Google   Spurl   Blink   Furl   Simpy   Y! MyWeb 
Thread Tools Search this Thread Display Modes
 
Unread Dev Articles Community Forums Sponsor:
  #1  
Old October 17th, 2005, 09:47 AM
realjag realjag is offline
Registered User
Dev Articles Newbie (0 - 499 posts)
 
Join Date: Oct 2005
Posts: 2 realjag User rank is Just a Lowly Private (1 - 20 Reputation Level) 
Time spent in forums: 1 h 4 m 49 sec
Reputation Power: 0
ifstream in function

Hi all. I'm a student learning C++.

I have worked through all of my problems on my latest project except for one.

I have to use a fuction to get input from a file.

I make this call:

getInput (month, rainfall);


and the function is this:

void getInput (int &rmonth, int &rrainfall)
{
//::input(ifstream& inData)
ifstream in_stream("rainInput.txt",ios::cur, ios::in);
//in_stream.open ("rainInput.txt", ifstream::in);
in_stream >> rmonth >> rrainfall;
//in_stream.close();
}
(pardon all of the comments, I was trying a few different things)

What happens is that the file is reopened everytime and data starts right from the beginning again. I tried appending data but that didn't do it.

I tried not re-opening but If I don't declare the file name in the function, in_stream is unidentified.

Yes, I'm very new and this is probably a fairly benign problem.

Thanks in advance.

Reply With Quote
  #2  
Old October 17th, 2005, 05:14 PM
B-Con's Avatar
B-Con B-Con is offline
:bcon: moderator
Dev Articles Newbie (0 - 499 posts)
 
Join Date: Apr 2005
Location: int main()
Posts: 351 B-Con User rank is Private First Class (20 - 50 Reputation Level)B-Con User rank is Private First Class (20 - 50 Reputation Level) 
Time spent in forums: 2 Days 23 h 1 m 43 sec
Reputation Power: 4
hm, assuming you had to leave that function parameter as is and could change what arguements it's allowed to take, I'd recommend the following:

Use a file pointer to open the file, but make the file pointer a global variable. Then just use the file pointer in the function. That way, whenever the function exits, it's doesn't close the file pointer.
Comments on this post
Icon agrees: Make the ifstream a global variable if you don't want to change the function, but in general avoid
globals!
__________________
Officially a member of the Itsacon fan club. Beer blasts are every friday at Viper_SB's house. I bring the chips.



Reply With Quote
  #3  
Old October 18th, 2005, 11:26 PM
realjag realjag is offline
Registered User
Dev Articles Newbie (0 - 499 posts)
 
Join Date: Oct 2005
Posts: 2 realjag User rank is Just a Lowly Private (1 - 20 Reputation Level) 
Time spent in forums: 1 h 4 m 49 sec
Reputation Power: 0
Quote:
Originally Posted by B-Con
hm, assuming you had to leave that function parameter as is and could change what arguements it's allowed to take, I'd recommend the following:

Use a file pointer to open the file, but make the file pointer a global variable. Then just use the file pointer in the function. That way, whenever the function exits, it's doesn't close the file pointer.


Thanks guys for the help. I'll give it a try.

Reply With Quote
Reply

Viewing: Dev Articles Community ForumsProgrammingC/C++ Help > ifstream in function


Thread Tools  Search this Thread 
Search this Thread:

Advanced Search
Display Modes  Rate This Thread 
Rate This Thread:


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

vB code is On
Smilies are On
[IMG] code is On
HTML code is Off
View Your Warnings | New Posts | Latest News | Latest Threads | Shoutbox
Forum Jump


Forums: » Register « |  User CP |  Games |  Calendar |  Members |  FAQs |  Sitemap |  Support | 
  
 





© 2003-2008 by Developer Shed. All rights reserved. DS Cluster 5 hosted by Hostway