seventheyejosh Posted September 20, 2009 Share Posted September 20, 2009 So here is a very stripped down version of my code, but it is throwing the same error. Basically (I think, the cin (buffer?)) is not getting reset, and some maybe hidden characters are being carried over to the next iteration of the loop. int choice; bool built=false; while(!built){ cout << "Enter your number: "; cin >> choice; cin.get(); if(choice>0 && choice<7){ //stuff that may lead to built=true; }else{ cout << "\n\nYour number must be between 1 and 6!!!\n\n"; }//end if }//end while if you enter a number it checks just fine. if you enter a letter though, it just goes into an endless loop like this: Enter your number: 5 //ok Enter your number: 8 //errors but works Enter your number: k //letter Enter your number: Your number must be between 1 and 6!!! Enter your number: Your number must be between 1 and 6!!! Enter your number: Your number must be between 1 and 6!!! Enter your number: Your number must be between 1 and 6!!! Enter your number: Your number must be between 1 and 6!!! - - - - - - and so on forever can someone point me in the correct direction? thanks! Quote Link to comment Share on other sites More sharing options...
KevinM1 Posted September 20, 2009 Share Posted September 20, 2009 Why are you using both >> and get()? Shouldn't you only be using the >> operator in this case? Quote Link to comment Share on other sites More sharing options...
seventheyejosh Posted September 20, 2009 Author Share Posted September 20, 2009 Since I'm not using the system(); commands, I use this at the end of my code to simulate the end button cout << "Thanks for playing \n\nPress Enter to exit..."; // system("PAUSE"); workaround cin.get(); return(0); if I don't do the cin.get(), there are the extra 2 characters left in space. there was a thread here http://www.phpfreaks.com/forums/index.php/topic,268620.0.html that I had the issue in and corbin helped me fix... Quote Link to comment Share on other sites More sharing options...
KevinM1 Posted September 20, 2009 Share Posted September 20, 2009 Since I'm not using the system(); commands, I use this at the end of my code to simulate the end button cout << "Thanks for playing \n\nPress Enter to exit..."; // system("PAUSE"); workaround cin.get(); return(0); if I don't do the cin.get(), there are the extra 2 characters left in space. there was a thread here http://www.phpfreaks.com/forums/index.php/topic,268620.0.html that I had the issue in and corbin helped me fix... Ah. Back when I was learning C++ in the late 90's, we only ever used the >> operator for input. If we wanted to terminate the loop, we'd feed it an end of line/file character, which was Ctrl-D on our linux machines. So, typically our loops would look like: while (cin >> someInput, cout << "=> ") { //do stuff } Unfortunately, my C++ is weak, so I'm not sure what is causing your problem. Quote Link to comment Share on other sites More sharing options...
guddoosk Posted October 19, 2009 Share Posted October 19, 2009 Hi seventheyejosh, The problem with your code is that your condtion checks just for numeric values between 1-7 and not the other values. In C++ internal typecasting is done as per the type of variable you are taking into account. You have taken the choice variable as an int and this means that every value in this will be stored as an int. When you type a character as input, its relevant ascii code gets stored in thechoice variable and this is not the same value between 0 and 7. The cin.get() might not have any role to play at this stage as your condition does not check for the input recieved via this statement. It just checks the choice variable. Hope this answers your query. Cheers, guddoosk Quote Link to comment Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.