C++中cin>>n的返回值

cin>>n的返回值

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
 
int main()
{
	int n,temp;
	vector<int> arr;
	while(cin>>n)
	{
		for(int i=0;i<n;i++)
		{
			cin>>temp;
			arr.push_back(temp);
		}
 
		sort(arr.begin(),arr.end());
 
		for(int i=0;i<n;i++)
			cout<<arr[i]<<" ";
		cout<<endl;
 
		system("pause");
		return 0;
 
	}
}

cin>>n作為判斷條件返回的是什麼值呢?

如果要輸出正確結果,這個判斷條件必須在客戶想要結束程序的時候結束輸入,要怎麼做呢?如果輸入一個錯誤的類型,cin會失效,循環也會停止,但是這樣做畢竟是個錯誤,那麼究竟要怎樣做才能正常結束這個循環呢?

【註意】

cin>>n返回的也是一個cin對象,當一個cin對象作為條件選擇、循環等的控制表達式時,編譯器會將其轉換為真值表達式,如果cin的iostate為goodbit,則這個真值表達式的結果為真,否則為假。

輸入一個非數字可以置位failbit,從而結束循環,當然這是一個非正常退出。

正常退出可以用鍵盤模擬產生EOF,表示流輸入結束瞭。在windows中可以輸入ctrl+z,unix/linux中則為ctrl+d。

scanf和cin的返回值問題

scanf

scanf是一個函數,它的返回值是一個int,該int代表scanf成功讀取到數據的個數,如果讀到文件末尾或者輸入ctrl+z標志讀取完畢的時候就會讀到EOF,這是它會返回0,相當於false;

int n;
    while (scanf("%d", &n) != EOF)
    {
        getchar();//吃掉回車
        cout<<n<<endl;
    }

cin

首先 cin是一個ios(iostream)中的對象,那麼他不是函數,不存在什麼返回值;

int n;
	while (cin>>n)
	{
		cout << "flag" << endl;
	}

這段程序看起來好像cin返回瞭值作為while中的條件判斷,實際上cin是一個對象,無返回值,而這個返回值是std中重載>>這個運算符返回的,其類型是一個istream&,這也說明瞭可以cin>>a>>b這樣連用的場景;

[外鏈圖片轉存失敗,源站可能有防盜鏈機制,建議將圖片保存下來直接上傳(img-ahJpo6qF-1655438506866)(../img/image-20220617114231728.png)]

那麼既然返回值是一個istream&類型,那麼這個類型的對象怎麼作為條件邏輯判斷的呢?

istream作為ios繼承的一個類型,其中重載瞭bool這個操作符別名,使得istream其對象可以調用bool操作符(相當於加瞭一個本類型與bool類型的轉換函數),該函數選擇性的返回給條件判斷語句true或者false,比如istream的對象 如果收到EOF(ctrl+z)就會return false,這也說明瞭while(cin>>n)當傳入EOF能停下來的原因;

則下面兩段代碼等價:

int n;
	while (cin>>n)
	{
		cout << "flag" << endl;
	}
	
int n;
	while ((cin>>n).bool())
	{
		cout << "flag" << endl;
	}

如果某個類型沒有重載bool操作符,那麼它就不能用於條件邏輯判斷;

class A
{
public:
	int a = 0;
};
int main() {
	A a;
	if (a) cout << 1 << endl;
	else cout << 0 << endl;
	return 0;
}

添加重載bool操作符;

class A
{
public:
	int a = 0;
	operator bool()//註意 轉換函數比較特殊 無返回值
	{
		if(a==0) return false;
		return true;
	}
};
int main() {
	A a;
	if (a) cout << 1 << endl;
	else cout << 0 << endl;
	return 0;
}

要註意的是 這裡operator bool()相當於是一個原生類型與bool類型的轉換函數,會返回一個bool值給邏輯表達式作為判斷,但是重載operator bool()的時候無返回值!這是其特殊的地方!

因此,若想使用自定義類型作為邏輯判斷表達式的判斷依據,隻要在這個類型中設置轉換函數即重載operator bool()即可;

小結一下

1**.scanf是一個函數**,返回值為一個int,代表scanf讀入對象的個數,如果其讀到EOF結束標志,會返回0相當於false;

2.cin是一個istream類型對象,他能作為判斷語句的原因是istream類型中的>>操作符會返回一個istream對象(cin),如果>>讀到EOF那麼返回的istream對象(cin)中會檢測到EOF的存在,那麼istream類型的operator bool()轉換函數起作用將這個對象(cin)轉換成bool類型false作為條件判斷;

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: