雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網!

C語言

當前位置:主頁 > 軟件編程 > C語言 >

c++運算符重載基礎知識詳解

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊:

實際上,很多C++運算符已經被重載。eg:將*運算符用于地址,將得到存儲在這個地址中的值,將他用于2個數字時,得到的將是他們的乘積。C++根據操作數的數目和類型來決定采用哪種操作。

C++允許將運算符重載擴展到用戶定義的類型。例如,允許使用+將兩個對象相加。編譯器將根據操作數的數目和類型決定使用加法定義。運算符重載可以使代碼看起來更自然。例如,將2個數組相加是一種常見的運算。通常,需要使用下面這樣的for循環(huán)來實現:

復制代碼 代碼如下:

for (int i = 0; i < 20; i++)
evening[i] = sam[i] + janet[i]; // add element by element

但在C++中,可以定義一個表示數組的類,并重載+運算符,于是便有這樣的語句:

total = arr1+arr2;
一個計算時間的例子
mytime.h

復制代碼 代碼如下:

#include"stdafx.h"
#include"MyTime.h"
#include<iostream>

int_tmain(intargc,_TCHAR*argv[])
{
//比導入整個名稱空間更經濟
usingstd::cout;
usingstd::endl;

Timeplanning;
Timecoding(2,50);
Timefixing(5,55);
Timetotal;
cout<<"planningtime=";
planning.Show();
cout<<endl;
cout<<"codingtime=";
coding.Show();
cout<<endl;
cout<<"fixingtime=";
fixing.Show();
cout<<endl;
total=coding.Sum(fixing);
cout<<"coding.Sum(fixing)=";
total.Show();
cout<<endl;
total=coding+fixing;
cout<<"coding+fixing=";
total.Show();
cout<<endl;
getchar();
return0;
}

調用

復制代碼 代碼如下:

#include"stdafx.h"
#include"MyTime.h"
#include<iostream>

int_tmain(intargc,_TCHAR*argv[])
{
//比導入整個名稱空間更經濟
usingstd::cout;
usingstd::endl;

Timeplanning;
Timecoding(2,50);
Timefixing(5,55);
Timetotal;
cout<<"planningtime=";
planning.Show();
cout<<endl;
cout<<"codingtime=";
coding.Show();
cout<<endl;
cout<<"fixingtime=";
fixing.Show();
cout<<endl;
total=coding.Sum(fixing);
cout<<"coding.Sum(fixing)=";
total.Show();
cout<<endl;
total=coding+fixing;
cout<<"coding+fixing=";
total.Show();
cout<<endl;
getchar();
return0;
}

執(zhí)行結果

重點講解
1.sum函數中將參數聲明為引用,可以提高運行效率,節(jié)省內存

2.sum函數中,返回值不能是引用。因為sum對象是局部變量,在函數結束時將被刪除,因此引用將指向一個不存在的對象。使用返回類型Time意味著在刪除sum之前構造他的拷貝,調用函數將得到他的拷貝。

上一篇:c語言多進程tcp服務器示例

欄    目:C語言

下一篇:隊列的動態(tài)鏈式存儲實現代碼分享

本文標題:c++運算符重載基礎知識詳解

本文地址:http://www.jygsgssxh.com/a1/Cyuyan/3750.html

網頁制作CMS教程網絡編程軟件編程腳本語言數據庫服務器

如果侵犯了您的權利,請與我們聯(lián)系,我們將在24小時內進行處理、任何非本站因素導致的法律后果,本站均不負任何責任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網 版權所有