C++基础:[enter] Ctrl+Z [enter] 问题及"\n"输入输出问题

首先来一段代码,引出问题:

#include
#include

using namespace std;

int main()
{
	char ch;
	int count = 0;
	cin.get(ch);
	while(cin.fail()==false)
	{      
		cout << ch;
		count++;
		cout<< count;
		cin.get(ch);
	}
	cout << "\n" << count << "\n";
	system("PAUSE");
	return 0;
}   

其运行结果如下:

C++基础:[enter] Ctrl+Z [enter] 问题及 图一

 

C++基础:[enter] Ctrl+Z [enter] 问题及 图二

 

C++基础:[enter] Ctrl+Z [enter] 问题及 图三

 

问题一:为什么abcd[CTRL+Z][enter]程序不会结束,如图图一所示,而[enter][CTRL+Z][enter]却会退出程序?

问题二:如图三所示,为什么我输入的abcd四个字符,最后的count的值是5呢?

问题三:有什么办法输入abcd四个字符,最后的count的值也是4?

  1. 针对问题一,需要了解以下知识。
           输入缓冲是行缓冲。当从键盘上输入一串字符并按回车后,这些字符会首先被送到输入缓冲区中存储。每当按下回车键后,cin.get()就会检测 输入缓冲区中是否有了可读的数据。cin.get()还会对键盘上是否有作为流结束标志的Ctrl+Z或者 Ctrl+D键按下作出检查,其检查的方式有两种:阻塞式以及非阻塞式。
           阻塞式检查方式指的是只有在回车键按下之后才对此前是否有Ctrl+Z组合键按下进行检查,非阻塞式样指的是按下Ctrl+ D之后立即响应的方式。如果在按Ctrl+D之前已经从键盘输入了字符,则Ctrl+D的作用就相当于回车,即把这些字符送到输入缓冲区供读取使用,此时Ctrl+D不再起流结束符的作用。如果按Ctrl+D之前没有任何键盘输入,则Ctrl+D就是流结束的信号。
           Windows系统中一般采用阻塞式检查Ctrl+Z,Unix/Linux系统下一般采用非阻塞式的检查Ctrl+D。楼主是在Windows系统下,因此使用阻塞式的Ctrl+Z来标识流的结束。
           这种阻塞式的方式有一个特点:只有按下回车之后才有可能检测在此之前是否有Ctrl+Z按下。还有一个特点就是:如果输入缓冲区中有可读的数据则不会 检测Ctrl+Z(因为有要读的数据,还不能认为到了流的末尾)。还有一点需要知道:Ctrl+Z产生的不是一个普通的ASCII码值(就如图一和图二的小箭头所示),也就是说它产生的不是一个字符,所以不会跟其它从键盘上输入的字符一样能够存放在输入缓冲区。明白了这几点之后就可以来解释了。
           从键盘上输入abcd[CTRL+Z][enter]之后在Windows系统上是这样处理的:由于回车的作用,前面的abcd等字符被送到输入缓冲区(注意:上面说过了,^z不会产生字符,所以更不会存储到输入缓冲区,缓冲区中没有   ^z   的存在)。这时,cin.get()   检测 到输入缓冲区中已经有数据存在(因此不再检查是否有^z的输入),于是从缓冲中读取相应的数据。如果都读取完了,则输入缓冲区重新变为空, cin.get()   等待新的输入。可见,尽管有^z按下,但是由于在此之前还有其它输入字符(abcd),所以流也不会结束。
           因此,输入流结束的条件就是:^z之前不能有任何字符输入(回车除外),否则^z起不到流结束的作用。
           还可以进一步问,如图二所示,输入的是abcd[CTRL+Z]abcd,最后输出的如图三二行。这种情况可以理解为[CTRL+Z]是键盘输入的终止,但不是流的终止。
  2. 问题的原因是图三的输入是:abcd[enter],其中的[enter]是没有显示的,而cin.get()是会把[enter]当做字符的,并且还会输出它,就如图三所示,输出的5是换行的,要不然就会像图一和图二所示只有两行。其代码调试如下图所示。
    C++基础:[enter] Ctrl+Z [enter] 问题及
  3. 由问题一和问题二的答案可知,是不是输出abcd[CTRL+Z][enter]输出的就是4呢?然而答案并不是,其结果在图一就显示了。这是为什么呢?其程序调试结果截图如下:
    C++基础:[enter] Ctrl+Z [enter] 问题及
    这次读入的虽然不是换行符,但是读入的却是一个别的字符,这是为什么呢?

注:参考博客

你可能感兴趣的:(Cplusplus)