淺談c++中的while(cin)問題
xp系統(tǒng)中利用dev-cpp進(jìn)行編程,語句while(cin>>str),str是個(gè)string類型,在一行中輸入幾個(gè)string,末位加個(gè)ctrl+z,輸入沒有結(jié)束,除非出入換行后,再輸入ctrl+z才能跳出輸入。一直不明白未什么,解釋請(qǐng)看下。
輸入緩沖是行緩沖。當(dāng)從鍵盤上輸入一串字符并按回車后,這些字符會(huì)首先被送到輸入緩沖區(qū)中存儲(chǔ)。每當(dāng)按下回車鍵后,cin.get() 就會(huì)檢測(cè)輸入緩沖區(qū)中是否有了可讀的數(shù)據(jù)。cin.get() 還會(huì)對(duì)鍵盤上是否有作為流結(jié)束標(biāo)志的 Ctrl+Z 或者 Ctrl+D 鍵按下作出檢查,其檢查的方式有兩種:阻塞式以及非阻塞式。
阻塞式檢查方式指的是只有在回車鍵按下之后才對(duì)此前是否有 Ctrl+Z 組合鍵按下進(jìn)行檢查,非阻塞式樣指的是按下 Ctrl+D 之后立即響應(yīng)的方式。如果在按 Ctrl+D 之前已經(jīng)從鍵盤輸入了字符,則 Ctrl+D的作用就相當(dāng)于回車,即把這些字符送到輸入緩沖區(qū)供讀取使用,此時(shí)Ctrl+D不再起流結(jié)束符的作用。如果按 Ctrl+D 之前沒有任何鍵盤輸入,則 Ctrl+D 就是流結(jié)束的信號(hào)。
Windows系統(tǒng)中一般采用阻塞式檢查 Ctrl+Z、Unix/Linux系統(tǒng)下一般采用非阻塞式的檢查 Ctrl+D。樓主是在Windows系統(tǒng)下,因此使用阻塞式的 Ctrl+Z 來標(biāo)識(shí)流的結(jié)束。
這種阻塞式的方式有一個(gè)特點(diǎn):只有按下回車之后才有可能檢測(cè)在此之前是否有Ctrl+Z按下。還有一個(gè)特點(diǎn)就是:如果輸入緩沖區(qū)中有可讀的數(shù)據(jù)則不會(huì)檢測(cè)Ctrl+Z(因?yàn)橛幸x的數(shù)據(jù),還不能認(rèn)為到了流的末尾)。還有一點(diǎn)需要知道:Ctrl+Z產(chǎn)生的不是一個(gè)普通的ASCII碼值,也就是說它產(chǎn)生的不是一個(gè)字符,所以不會(huì)跟其它從鍵盤上輸入的字符一樣能夠存放在輸入緩沖區(qū)。明白了這幾點(diǎn)之后就可以來解釋樓主提出的問題了。
從鍵盤上輸入abcd^z 加 回車之后在Windows系統(tǒng)上是這樣處理的:由于回車的作用,前面的 abcd 等字符被送到輸入緩沖區(qū)(注意:上面說過了,^z不會(huì)產(chǎn)生字符,所以更不會(huì)存儲(chǔ)到輸入緩沖區(qū),緩沖區(qū)中沒有 ^z 的存在)。這時(shí),cin.get() 檢測(cè)到輸入緩沖區(qū)中已經(jīng)有數(shù)據(jù)存在(因此不再檢查是否有 ^z 的輸入),于是從緩沖中讀取相應(yīng)的數(shù)據(jù)。如果都讀取完了,則輸入緩沖區(qū)重新變?yōu)榭?,cin.get() 等待新的輸入??梢姡M管有 ^z 按下,但是由于在此之前還有其它輸入字符(abcd),所以流也不會(huì)結(jié)束。
因此,輸入流結(jié)束的條件就是:^z 之前不能有任何字符輸入(回車除外),否則 ^z 起不到流結(jié)束的作用。
以上這篇淺談c++中的while(cin)問題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
C語言中單鏈表(不帶頭結(jié)點(diǎn))基本操作的實(shí)現(xiàn)詳解
鏈表是一種物理存儲(chǔ)結(jié)構(gòu)上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過鏈表中的指針鏈接次序?qū)崿F(xiàn)的。本文主要和大家聊聊C語言中單鏈表(不帶頭結(jié)點(diǎn))的基本操作,感興趣的小伙伴可以了解一下2022-11-11C#委托所蘊(yùn)含的函數(shù)指針概念詳細(xì)解析
C#中用委托這種概念實(shí)現(xiàn)了函數(shù)指針技術(shù)而已,另外.ent提供額外的安全性,當(dāng)然也損失了靈活性2013-09-09超詳細(xì)解析C++實(shí)現(xiàn)歸并排序算法
歸并排序是比較穩(wěn)定的排序方法。它的基本思想是把待排序的元素分解成兩個(gè)規(guī)模大致相等的子序列。本文將用C++實(shí)現(xiàn)這一排序算法,需要的可以參考一下2022-09-09深入探討linux下進(jìn)程的最大線程數(shù)、進(jìn)程最大數(shù)、進(jìn)程打開的文件數(shù)
本篇文章是對(duì)linux下進(jìn)程的最大線程數(shù)、進(jìn)程最大數(shù)、進(jìn)程打開的文件數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C/C++編程判斷String字符串是否包含某個(gè)字符串實(shí)現(xiàn)示例
這篇文章主要為大家介紹了C++編程中判斷String字符串是否包含某個(gè)字符串的實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-11-11