- 突然又空,鉴于对cin对象的去值机制还不是很了解,就探究一番,并且记下来,方便以后复习。
1 #include <iostream> 2 3 int main(void) 4 { 5 using namespace std; 6 int date = 2; 7 char ch; 8 while (!(cin >> date)){ 9 cout << "Not a number. "; 10 cout << date << endl; 11 cin.clear();//若没有这句,这个函数会一直输出“Not a number”, 12 //原因是读取失败后,cin对象会设置失效位(failbit),导致接下来的输入被阻断 13 cin >> ch; 14 cout << ch << endl; 15 } 16 cout << date << endl; 17 return 0; 18 } 19 /************************** 20 * q 21 * Not a number. 22 * 0 23 * q 24 * 4 25 * 4 26 * ************************/ 27 ~
解释:
第 8 行:date是int型,但我故意输入一个字符q,所以cin>>ch返回false,while括号内为true,执行while循环.
第10行: 从代码中,可以知道date已经被初始化为2,但输出结果中,我们看到的date却变成0了,说明cin对象在取值时,会先将date变量中的值"2"踢走, 然后再将在cin>>date中输入的值放进date里,但在第八行我故意输入一个q,和date本身的类型不一样,所以无法将q放进date里.最后date只能是0了.(对于没有值的变量,默认是0)
第11行:在对date设值失败后,q留在了输入流中,并且“锁定了输入流”(错误标志被设置),也就是说后面的语句再也不能从输入流取值了。用clear()是“解锁”。
第13行:解锁之后,就可以将留在输入流中的q取走了,所以在14行输出的ch值就是q。
while:执行完14行后,又退回while括号内的判断。此时cin对象会要求你从键盘输入,这次输入4,所以while循环不执行,在第16行输出date的值4后,结束程序。 - 这一段是书本关于类型不匹配的描述:
初始条件(int n ; cin >> n)
如果输入的是单词而不是数字会怎样呢?
1,n值保持不变;------>这里好像和我上面的结论相冲.
2,不匹配的输入将被留在输入队列里;
3,cin对象的一个错误标志被设置; ——————意味着不能再输入数字,要用clear()重置。
4,对cin方法的调用将返回false(bool型)。————指的是在while或if中。
看第一点,很明显与我上面说的"将date变量中的值"2"踢走"矛盾:
1 #include <iostream> 2 3 int main(void) 4 { 5 using namespace std; 6 int n = 5; 7 cin >> n; 8 9 cin.clear(); 10 char ch; 11 cin >> ch; 12 cout << "ch: " << ch << endl; 13 14 cout << "n: " << n << endl; 15 return 0; 16 17 } 18 /*************************** 19 * e 20 * ch: e 21 * n: 0 22 * ************************/
结论:像上面程序输出所见,n的值在输入类型不匹配时,会被重值为0。大大的疑问,难道是我对这句话“n值保持不变”理解错了?这句话要在某些前提下才成立????先撇下,以后懂了来补洞。不用等了,现在就知道原因了:这个n值保持不变是指不匹配的类型没有被放进n里,仅此而已。但系统可以重置n值,所以我们见到了初始化为5的n变成了0.
看看其他的情况:1 #include <iostream> 2 3 const int Max = 5; 4 5 int main(void) 6 { 7 using namespace std; 8 int test[Max]; 9 10 int i; 11 for (i = 0 ; i < Max ; ++i){ 12 cout << "number#" << i << ": "; 13 while (!(cin >> test[i])){ 14 cin.clear(); //reset input 15 while (cin.get() != ' ') 16 continue; 17 cout << "Please enter a number:"; 18 } 19 } 20 21 cout << "You enter: "; 22 for (int i = 0 ; i < Max ; ++i){ 23 cout << test[i] << " "; 24 } 25 cout << endl; 26 27 return 0; 28 } 29 30 /************************************** 31 * number#0: 11 32 * number#1: 12 33 * number#2: 13 34 * number#4: qwefgf 35 * Please enter a number:16 36 * You enter: 11 12 13 15 16 37 * ************************************/
其他的情况在代码里,要好好看看。