while(cin>>ch)如何退出

转自:点击打开链接

while(cin>>ch)如何退出

标签: windows存储
887人阅读 评论(0) 收藏 举报
本文章已收录于:

方法:回车后,在新行Ctrl+z并回车。若输入数据后Ctrl+z再回车无效。

原因:

输入缓冲是行缓冲。当从键盘上输入一串字符并按回车后,这些字符会首先被送到输入缓冲区中存储。每当按下回车键后,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^z   加   回车之后在Windows系统上是这样处理的:由于回车的作用,前面的   abcd   等字符被送到输入缓冲区(注意:上面说过了,^z不会产生字符,所以更不会存储到输入缓冲区,缓冲区中没有   ^z   的存在)。这时,cin.get()   检测到输入缓冲区中已经有数据存在(因此不再检查是否有   ^z   的输入),于是从缓冲中读取相应的数据。如果都读取完了,则输入缓冲区重新变为空,cin.get()   等待新的输入。可见,尽管有   ^z   按下,但是由于在此之前还有其它输入字符(abcd),所以流也不会结束。

因此,输入流结束的条件就是:^z   之前不能有任何字符输入(回车除外),否则   ^z   起不到流结束的作用。

 

转自:http://bbs.suda123.com/Archiver/webbiancheng/thread-253234-1.html

0
0
 
 
我的同类文章
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这段代码实现了对二叉树的创建和中序遍历,并且输出的遍历结果包含了括号,用于表示运算符的优先级。如果需要换一个算法实现这个代码,可以使用栈来实现二叉树的创建和中序遍历。 具体实现方法如下: 1. 定义一个栈,用于存放节点; 2. 从输入中读取每一个元素,然后创建一个节点; 3. 如果当前元素为操作数,则将其压入栈中; 4. 如果当前元素为操作符,则将其作为根节点,将栈顶的两个节点分别作为左右子节点,并将根节点压入栈中; 5. 当所有元素都处理完毕后,栈中剩余的节点即为二叉树的根节点。 具体代码实现如下: ```C++ #include <iostream> #include <string> #include <stack> using namespace std; typedef string ElemType; typedef struct BitNode { ElemType data; struct BitNode* lchild, * rchild; } BitNode, * BiTree; void CreateBiTree(BiTree& t) { stack<BitNode*> s; BitNode* p, * q; string ch; cin >> ch; while (ch != "#") { p = new BitNode; p->data = ch; p->lchild = p->rchild = NULL; if (!t) { t = p; } if (!s.empty()) { q = s.top(); if (!q->lchild) { q->lchild = p; } else { q->rchild = p; s.pop(); } } if (ch[0] < '0' || ch[0] > '9') { s.push(p); } cin >> ch; } } void InOrderTraverse(BiTree t) { if (t) { string op = t->data; if (op[0] < '0' || op[0] > '9') { cout << '('; } InOrderTraverse(t->lchild); cout << t->data; InOrderTraverse(t->rchild); if (op[0] < '0' || op[0] > '9') { cout << ')'; } } } int main() { BiTree tree = NULL; string ch; while (cin >> ch) { CreateBiTree(tree); InOrderTraverse(tree); printf("\n"); tree = NULL; } return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值