#include "stdafx.h"
#include <iostream>
using namespace std;
int main(int argc, char* argv[])


{
const int ArSize=20;
char name[ArSize];
char dessert[ArSize];

cout<<"Enter yout name:\n";
cin>>name;
cout<<"Enter your favorite dessert:\n";
cin>>dessert;
cout<<"I have some delicious "<<dessert;
cout<<" for you."<<name<<endl;
return 0;
}
注意看下面我運行的輸入:

當我輸入Alistair Dreeb的時候,甚至沒有對“Enter your favorite dessert ”做出反應,程序便把它顯示出來了,然后立即顯示最后一行。
cin是如何確定已完成字符串輸入的呢?
由于不能通過鍵盤輸入空字符,因此cin需要用別的方法來確定字符串的結尾位置。cin使用空白(空格、制表符和換行符)來定字符串的界。這意味著cin在獲取字符數組輸入時只讀取一個單詞。讀取該單詞后,cin將該字符串放到數組中,并自動在結尾添加空字符。
這個例子的實際結果是,cin把Alistair作為第一個字符串,并將它放到name數組中,這把Dreeb留在輸入隊列中。當cin在輸入隊列中搜索用戶喜歡的甜點時,它發現了Dreeb,因此cin讀取Dreeb,并將它放到dessert數組中。
每次讀取一個單詞通常不是最好的選擇。所以需要采用另一種字符串讀取方法。具體地說,需要采用面向行而不是面向單詞的方法。istream中的類(如cin)提供了一些面向行的類成員函數:getline()和get()。兩個函數都讀取一行輸入,直到到達換行符。然而,隨后getline()將丟棄換行符,而get()將換行符保留在輸入序列中。 getline()函數讀取整行,使用回車鍵輸入的換行符來確定輸入結尾。調用這種方法,使用cin.getline()。該函數有兩個參數。第一個參數是用來存儲輸入行的數組的名稱,第二個參數是要讀取的字符數。如果這個參數為20,則函數最多讀取19個字符,余下的空間用于存儲自動在結尾處添加的空字符。getline()成員函數在賭氣指定數目的字符或遇到換行符時停止讀取。getline()函數每次讀取一行,通過換行符來確定行尾,但不保存換行符。相反,在存儲字符串時,它用空字符來替換換行符。
get()函數,有幾種變體。其中一種變體的工作方式與getline類似,但get并不再讀取并丟棄換行符,而是將其留在輸入隊列中。假設連續兩次調用get():
cin.get(name, ArSize);
cin.get(dessert, ArSize);
由于第一次調用后,換行符將留在輸入隊列中,因此第二次調用時看到的第一個字符便是換行符。因此get()認為已到達行尾,而沒有發現任何可讀取的內容。如果不借助于幫助,get()將不能跨過該換行符。幸運的是,get()有一種,不帶任何參數的cin.get()調用讀取下一個字符(即使是換行符),的變體。因此可以用它來處理換行符,為讀取下一行輸入做好準備。
cin.get(name, ArSize);
cin.get();
cin.get(dessert, ArSize);
另一種使用get()的方式是將兩個類成員函數拼接起來(合并),如下所示
cin.get(name, ArSize).get(); //concatenate member functions
cin.get(name, ArSize)返回一個cin對象,該對象隨后將被用來調用get()函數。
注意:有些C++的老版本沒有實現不接受任何參數的get()變體,但實現了接受一個char參數的get()變體。要使用該變體(而不是沒有參數get()),需要首先聲明一個char變量:
char ch;
cin.get(name, ArSize).get(ch); getline()使用起來簡單些,但get()使得檢查錯誤更簡單些。
當getline()或get()讀取空行時,將發送什么情況? 最初的做法是,下一條輸入語句將在前一條getline()或get()結束讀取的位置開始讀取;但當前的做法是,當get()(不是getline())讀取空行后將設置失效位(failbit)。這意味著接下來的輸入將被阻斷,但可以用下面的命令恢復輸入:
cin.clear();
如果輸入行的字符數比指定的多,則getline()和get()將把余下的字符留在輸入隊列中,而getline()還會設置失效位,并關閉后面的輸入。
另一個問題是,輸入字符串可能比目標數組長。