C++簡單又好用的基本運算符重載

運算符重載概念

對已有的運算符進行重新定義,賦予其另外一種功能,以適應不同的數據類型

我們知道已有的運算符有'+'、'-'、'*'、'/'等,這些運算符對於內置數據類型可以直接使用,例如int、float、double、char等等。但是如果我們定義一個類,想實現類中對象屬性的加減乘除運算,該怎麼實現呢?那就用到運算符重載的知識點瞭。

加號運算符重載

學會一個頂四個,這篇博文隻舉例加號運算符重載

成員函數實現

示例:

class Person
{
public:
	Person operator+(Person p)
	{
		Person temp; 
		temp.m_a = this->m_a + p.m_a;
		temp.m_b = this->m_b + p.m_b;
		return temp;
	}
	int m_a;
	int m_b;
};
int main()
{
    Person p1, p2;
    p1.m_a = 10, p2.m_a=20;
    p1.m_b = 30, p2.m_b = 40;
    Person pa = p1.operator+(p2);
    Person pb =p1+p2;
}

定義Person類,聲明兩個整型屬性,我們都知道在類內定義的函數為成員函數或者方法;這個成員函數的返回值為Person類型,意為返回的話會自動調用編譯器提供的拷貝構造函數,這個在前面的文章已經提到過,這裡註意函數名不要自定義瞭,就寫operator+,英文意思就是’+‘操作,這樣定義符合編譯器規范,可以使用簡化版的運算,然後參數也是Person類型的,這是因為我們的目的就是要實現自定義類型的運算;該函數的實現也很簡單,就是將各屬性相加後的結果返回給新的對象;主函數中pa和pb的兩個屬性均會相等,pa的調用是重載的本質調用,pb的則是簡化的調用,看一下運行結果:

全局函數實現

示例:

Person operator+(Person p1,Person p2)
{
	Person temp;
	temp.m_a = p1.m_a + p2.m_a;
	temp.m_b = p1.m_b + p2.m_b;
	return temp;
}
Person pa = operator+(p1, p2);
Person pb = p1+p2;

在類外面定義的函數為全局函數,和上面成員函數的區別就是多瞭一個Person類型的參數而已;也是新建一個對象,讓其屬性等於參數的屬性之和,最後返回這個結果,我們還是隻需要新創建一個對象來等於這個結果就行瞭,全局函數也分本質調用和簡化調用兩種。

運算符實現函數重載

運算符重載也可以發生函數重載,就是在同一個作用域下,相同函數名的函數可以實現不一樣的功能。

示例:

Person operator+(Person p1, int v)
{
	Person temp;
	temp.m_a = p1.m_a + v;
	temp.m_b = p1.m_b + v;
	return temp;
}

這裡是一個全局函數的寫法,傳入對象參數p1和整型數據v,讓新建對象的屬性等於傳入對象參數的屬性都和v相加並返回該結果給新創建的對象,寫完改函數就可以直接進行這樣的調用瞭:

int main()
{
	Person p1, p2;
	p1.m_a = 10, p2.m_a=20;
	p1.m_b = 30, p2.m_b = 40; 
	Person pa = p1 + p2;
	Person pb = operator+(p1, p2);
	Person p4 = pa + pb;
	Person p5 = p4 + 10;
	cout << "pa的屬性為:" <<pa.m_a << pa.m_b << endl;
	cout << "pb的屬性為:" <<pb.m_a << pb.m_b << endl;
	cout << "p4的屬性為:" <<p4.m_a << p4.m_b << endl;
	cout << "p5的屬性為:" << p5.m_a << p5.m_b << endl;
}

運行效果:

總結

直接對自定義的類進行運算應該很舒服吧,反正我用著很爽,另外的減號、乘除的重載可以按照加號運算符重載的方法一步步實現,有興趣的朋友一定早已躍躍欲試瞭,感謝大傢的觀看,快去嘗試吧

到此這篇關於C++簡單又好用的基本運算符重載的文章就介紹到這瞭,更多相關C++運算符重載內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: