亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

聊聊C++ 運(yùn)算符重載知識(shí)

 更新時(shí)間:2021年11月11日 14:38:28   作者:Sauron7i  
運(yùn)算符重載是一種形式的C++多態(tài),重載運(yùn)算符可以使代碼看起來更加自然,下面通過例子介紹下C++ 運(yùn)算符重載知識(shí),感興趣的朋友一起看看吧

前言

1.運(yùn)算符重載是一種形式的C++多態(tài)。
2.重載運(yùn)算符可以使代碼看起來更加自然。

回顧類

在正常構(gòu)造類的時(shí)候,有些成員方法可以不用寫出來,例如在這樣一個(gè)表示時(shí)間的類中,拷貝構(gòu)造函數(shù)只是淺拷貝,和系統(tǒng)默認(rèn)的步驟是一樣的,可以不用寫了。 同樣,析構(gòu)函數(shù)如果在對(duì)象死亡之前沒有必須要做的事情,也可以不用寫。

所以在下面的例子中,拷貝構(gòu)造和析構(gòu)函數(shù)可以省略。

class Time
{
public:
	Time();
	Time(const Time& src)
	{
		_hour = src._hour;
		_minutes = src._minutes;
	}
	~Time();
private:
	int _hour;
	int _minutes;
};

通過示例引入運(yùn)算符重載

示例

若要將兩個(gè)等數(shù)組中各個(gè)下標(biāo)對(duì)應(yīng)的字符相加,普通寫法為:

#include<iostream>
using namespace std;
int main(void)
{
	const int SIZE = 10;
	int ch1[SIZE] = { 0,1,2,3,4,5,6,7,8,9 };
	int ch2[SIZE] = { 9,8,7,6,5,4,3,2,1,0 };
	int ch3[SIZE];

	for (int i = 0; i < SIZE; ++i)
	{
		ch3[i] = ch1[i] + ch2[i];
	}
	
	for (int i = 0; i < SIZE; ++i)
	{
		cout << ch3[i] << " ";
	}
	cout << endl;
	return 0;
}

這樣是可以正常輸出的:

在這里插入圖片描述

再來看看運(yùn)算符重載的示例,這里使用的是 string 類。

#include<iostream>
#include<string>
using namespace std;

int main(void)
{
	string s1 = "aaaa";
	string s2 = "bbbb";
	string s3 = s1 + s2;

	cout << s3 << endl;
	return 0;
}

在這里插入圖片描述

這里的 s1 + s2就是運(yùn)用的加法運(yùn)算符重載,內(nèi)部實(shí)現(xiàn)也是對(duì)應(yīng)的下標(biāo)再加,但這樣簡(jiǎn)單的寫法,強(qiáng)調(diào)了實(shí)質(zhì)。

定義

要重載運(yùn)算符,需要使用被稱為運(yùn)算符函數(shù)的特殊函數(shù)形式。

格式:

 ret_form operator op(argument-list)

例如加法運(yùn)算符:

operator +();

可重載的運(yùn)算符

這里開個(gè)玩笑,列出這寫可重載的,大家有興趣可以自己實(shí)現(xiàn)。

在這里插入圖片描述

本文講述的類

下面是文章示例的一個(gè)類:

表示一個(gè)復(fù)數(shù)

class Complex
{
public:
	//默認(rèn)構(gòu)造
	Complex();

	//構(gòu)造函數(shù)
	Complex(int a, int b)
	{
		_a = a;
		_b = b;
	}
	
	//打印
	void show()
	{
		cout << _a << "+" << _b << endl;
	}
	//析構(gòu)函數(shù)
	~Complex()
	{
		cout << "Program Exit" << endl;
	}

private:
	int _a; //實(shí)部
	int _b; //虛部
}

加法運(yùn)算符

如果要使用到加法,如

int main(void)
{
	Complex s1(1, 2);
	Complex s2(2, 3);

	Complex s3 = s1 + s2;
	
	return 0;
}

那首先要確定,我不能改變加數(shù)原本的值,其次,我需要返回一個(gè)加完之后的類。

那重載加法運(yùn)算符聲明就可寫成:

1.返回類型為 類 類型
2.this指針聲明成const
3.第二個(gè)加數(shù)聲明為const

Complex operator +(const Complex& src)const;

函數(shù)實(shí)現(xiàn):
這里還用到了構(gòu)造函數(shù),將其構(gòu)造后返回。

//加法運(yùn)算符
	Complex operator +(const Complex& src)const
	{
		int a = _a + src._a;
		int b = _b + src._b;
		return Complex(a, b);
	}

使用運(yùn)算符的兩種方式:

s3和s4用到的方式都可以

	Complex s1(1, 2);
	Complex s2(2, 3);

	Complex s3 = s1 + s2;
	Complex s4 = s1.operator+(s2);

運(yùn)行示例:
輸出了 s3 和s4, 并且析構(gòu)。

在這里插入圖片描述

&& 運(yùn)算符

比如要寫一個(gè)方法來判斷兩個(gè)復(fù)數(shù)的實(shí)部是否都為0.

	if (s1 && s2)
	{
		cout << "all zero" << endl;
	}

實(shí)現(xiàn):

	//&&
	bool operator &&(const Complex& src)const
	{
		return _a && src._a;
	}

cout<<運(yùn)算符

想要重載輸出運(yùn)算符,首先想到的是將 cout 當(dāng)作參數(shù)傳遞給函數(shù)。

簡(jiǎn)易版(相當(dāng)于show())

	//cout <<
	void operator <<(ostream& out)
	{
		out << _a << "+" << _b << "i" << endl;
	}

這樣重載的話,就只能當(dāng)作show()方法一樣調(diào)用。而不能直接使用cout。

在這里插入圖片描述

臻享版

首先要知道,cout是一個(gè)二元運(yùn)算符,那我們傳遞參數(shù)的時(shí)候,也是傳遞兩個(gè)參數(shù),向上面的簡(jiǎn)易版,第一個(gè)參數(shù)為this指針, 第二個(gè)才是cout ,如果想把this指針移到第二個(gè)參數(shù)位置,是辦不到的,所以只能當(dāng)作show方法的樣子來寫。

void operator <<(/*this*/ostream& out)
	{
		out << _a << "+" << _b << "i" << endl;
	}

解決方法:
把要輸出的參數(shù)放在第二個(gè)位置。

這里就需要在類外實(shí)現(xiàn),實(shí)現(xiàn)的方法利用友元性質(zhì),放入類中。

如圖所示,我確實(shí)是在類外寫的。

在這里插入圖片描述

運(yùn)行示例:
這里直接寫cout << s1

int main(void)
{
	Complex s1(1, 2);
	Complex s2(2, 3);

	Complex s3 = s1 + s2;
	Complex s4 = s1.operator+(s2);

	s3.show();
	s4.show();
	//s1.operator<<(cout);
	cout << s1;

	return 0;
}

沒有問題,把 1+2i 輸出了

在這里插入圖片描述

但如果想要連續(xù)輸出,例如:

cout << s1 << s2;

我像上面那樣寫就不行了,因?yàn)檫@個(gè)方法的返回類型是void,函數(shù)參數(shù)先接收 cout 和 s1, 然后返回void,將void 和 s2又當(dāng)作參數(shù)傳遞過去,顯然是不行的。

解決方法:
將這個(gè)方法的返回類型寫成輸出流對(duì)象, 即ostream

ostream& operator <<(ostream& out, const Complex& src)
{
	out << src._a << "+" << src._b << "i" << endl;
	return out;
}

同樣友元函數(shù)也寫成:

friend ostream& operator <<(ostream& out, const Complex& src);

這樣寫的話就可以連續(xù)輸出

示例:若要輸出三個(gè)對(duì)象

cout << s1 << s2 << s3;

運(yùn)行結(jié)果

在這里插入圖片描述

++運(yùn)算符 前置++

前置++的意思是先 自加1,再返回。

實(shí)現(xiàn):
這里只針對(duì)復(fù)數(shù)的實(shí)部

	//前置++
	Complex& operator ++()
	{
		++_a;
		return *this;
	}

后置++

后置++的意思是先傳值,再自增1 。

實(shí)現(xiàn):
參數(shù)列表里的int沒有實(shí)質(zhì)意義,只是讓編譯器區(qū)分前置還是后置。

	//后置++
	Complex operator ++(int)
	{
		int tmp = _a;
		_a++;
		return Complex(tmp, _b);
	}

練習(xí)

通過上面介紹的這些運(yùn)算符重載,可以寫出其他一些。

這里可以實(shí)現(xiàn)有
減法運(yùn)算符、 ||運(yùn)算符、 >>運(yùn)算符 和 自減運(yùn)算符(- -)。

例如減法運(yùn)算符:和加法一樣的寫法:

	//減法運(yùn)算符
	Complex operator -(const Complex& src)const
	{
		int a = _a - src._a;
		int b = _b - src._b;
		return Complex(a, b);
	}

到此這篇關(guān)于C++ 運(yùn)算符重載 簡(jiǎn)介的文章就介紹到這了,更多相關(guān)C++ 運(yùn)算符重載內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論