首頁 > 軟體

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

2022-07-25 14:03:52

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這樣連用的場景;

那麼既然返回值是一個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作為條件判斷;

以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com