background image

  昨天一个同学问到一个 C++运算符重载的问题,如下代码,其中的 while 循环起什
么作用,好像注释掉后程序运行没什么差别:

以下是引用片段:

  iostream& operator >> (iostream& is, b& s) 
  ...{ 
  char temp[b::MAX] = ...{0}; 
  is.get(); 
  is.get(temp, b::MAX); 
  if(strlen(temp)>0) 
  ...{ 
  strncpy(b.str, temp, b::MAX); 
  } 
  while(is && is.get()!=' ') 
  ...{ 
  continue; 
  } 
  return is; 
  }

  其中,b 为一个自定义的类型,其中含有一个 char str[b::MAX] 的私有成员,

b::MAX 为一个代表字符串长度的宏定义。
  可见,当通过>>输入字符串的长度超过 b::MAX 长度时,while 循环就起作用了,它
会丢弃超过 b::MAX 长度的输入缓冲区的内容,直到换行符出现为止,实际上就是一个清
缓冲区的功能,以待下一次重新输入字符串。为了验证我的分析,做了如下测试:

以下是引用片段:

  b b1, b2; 
  cin >> b1; 
  cin >> b2; 
  b1.show(); 
  b2.show();

  果然,当输入字符串小于 b::MAX 时一切正常,当超过 b::MAX 时,当输入完第一个
字符串回车后,没等输入第二个字符串,程序就把 b1 和 b2 的内容都显示出来了,而 b2 
的内容正是输入的字符串超过 b::MAX 长度的部分,说明前面的分析是正确的。
  今天又想起这个问题,突然联想到以前 C 语言的两个 scanf 连用产生的问题,灵机
一动,难道也是输入缓冲区没有自动清空产生的问题?当连续用 scanf 输入两个字符的时
候,输入第一个字符后回车,结果换行符被当作第二个字符输入了,scanf 可不会区分什
么换行符还是普通字符,而当输入一个字符,再输入一个整数时,因为类型不匹配的原
因,scanf 会将换行符忽略而等待输入正确的整数后才返回,所以得到了正确的结果,哈
哈,原来如此!!!