雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網(wǎng)!

C語言

當前位置:主頁 > 軟件編程 > C語言 >

淺談c++中的while(cin)問題

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊:

xp系統(tǒng)中利用dev-cpp進行編程,語句while(cin>>str),str是個string類型,在一行中輸入幾個string,末位加個ctrl+z,輸入沒有結(jié)束,除非出入換行后,再輸入ctrl+z才能跳出輸入。一直不明白未什么,解釋請看下。

輸入緩沖是行緩沖。當從鍵盤上輸入一串字符并按回車后,這些字符會首先被送到輸入緩沖區(qū)中存儲。每當按下回車鍵后,cin.get()   就會檢測輸入緩沖區(qū)中是否有了可讀的數(shù)據(jù)。cin.get()   還會對鍵盤上是否有作為流結(jié)束標志的   Ctrl+Z   或者   Ctrl+D   鍵按下作出檢查,其檢查的方式有兩種:阻塞式以及非阻塞式。   

阻塞式檢查方式指的是只有在回車鍵按下之后才對此前是否有   Ctrl+Z   組合鍵按下進行檢查,非阻塞式樣指的是按下   Ctrl+D   之后立即響應(yīng)的方式。如果在按   Ctrl+D   之前已經(jīng)從鍵盤輸入了字符,則   Ctrl+D的作用就相當于回車,即把這些字符送到輸入緩沖區(qū)供讀取使用,此時Ctrl+D不再起流結(jié)束符的作用。如果按   Ctrl+D   之前沒有任何鍵盤輸入,則   Ctrl+D   就是流結(jié)束的信號。     

Windows系統(tǒng)中一般采用阻塞式檢查   Ctrl+Z、Unix/Linux系統(tǒng)下一般采用非阻塞式的檢查   Ctrl+D。樓主是在Windows系統(tǒng)下,因此使用阻塞式的   Ctrl+Z   來標識流的結(jié)束。    

這種阻塞式的方式有一個特點:只有按下回車之后才有可能檢測在此之前是否有Ctrl+Z按下。還有一個特點就是:如果輸入緩沖區(qū)中有可讀的數(shù)據(jù)則不會檢測Ctrl+Z(因為有要讀的數(shù)據(jù),還不能認為到了流的末尾)。還有一點需要知道:Ctrl+Z產(chǎn)生的不是一個普通的ASCII碼值,也就是說它產(chǎn)生的不是一個字符,所以不會跟其它從鍵盤上輸入的字符一樣能夠存放在輸入緩沖區(qū)。明白了這幾點之后就可以來解釋樓主提出的問題了。   

從鍵盤上輸入abcd^z   加   回車之后在Windows系統(tǒng)上是這樣處理的:由于回車的作用,前面的   abcd   等字符被送到輸入緩沖區(qū)(注意:上面說過了,^z不會產(chǎn)生字符,所以更不會存儲到輸入緩沖區(qū),緩沖區(qū)中沒有   ^z   的存在)。這時,cin.get()   檢測到輸入緩沖區(qū)中已經(jīng)有數(shù)據(jù)存在(因此不再檢查是否有   ^z   的輸入),于是從緩沖中讀取相應(yīng)的數(shù)據(jù)。如果都讀取完了,則輸入緩沖區(qū)重新變?yōu)榭?,cin.get()   等待新的輸入??梢?,盡管有   ^z   按下,但是由于在此之前還有其它輸入字符(abcd),所以流也不會結(jié)束。   

因此,輸入流結(jié)束的條件就是:^z   之前不能有任何字符輸入(回車除外),否則   ^z   起不到流結(jié)束的作用。

以上這篇淺談c++中的while(cin)問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持我們。

上一篇:C++二維數(shù)組中的查找算法示例

欄    目:C語言

下一篇:C++實現(xiàn)單鏈表按k值重新排序的方法

本文標題:淺談c++中的while(cin)問題

本文地址:http://www.jygsgssxh.com/a1/Cyuyan/1609.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負任何責任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有