person.h
#include
#include
#include
using namespace std;
#ifndef _person
#define _person
class person
public: //運算子過載
void operator=(person& temp)
//& 引用傳遞
person operator+(person& temp)
//轉換成int
//型別轉換 1、不能指定返回型別 2、無參
// 顯示轉換 運算子過載 不能定義為全域性
//--》 int i = (int)oneperson;
operator int()
//前置++
person& operator++()
//後置++ 先賦值後加
person operator++(int)
//下標取字元
char operator(int temp)
/*
new 運算子過載
1、必須是static [注意:此處可以不加static 編譯器都認為是靜態的運算子過載]
2、返回值必須是 void*
3、可以帶多個引數, 但第乙個引數必須是size_t
[typedef unsigned int size_t;]
*/
void* operator new(size_t)
void* operator new(size_t temp)
}public: //析構函式
~person();
public://友元
//friend person operator+(person& temp1, person& temp2);
friend ostream& operator<
friend void operator>>(istream&, person&);
};#endif _person
person.cpp
#include "person.h"
#include
using namespace std;
#include
/*-----------------------
建構函式
------------------------*/
person::person()
person::person(int id, char * name)
/*-----------------------
常用函式
------------------------*/
void person::printmsg()
void person::setname(char * name)
int person::getnamelen()
/*-----------------------
析構函式
------------------------*/
person::~person()}
operator.cpp
#include
#include
using namespace std;
#include
#include "person.h"
//全域性 運算子過載 在person類中宣告為友元 才有訪問成員變數的許可權
/*person operator+(person& temp1, person& temp2)
*///輸出 運算子過載 需在類中宣告為 友元
C 運算子過載 過載特殊運算子
賦值運算子用於同類物件間的相互賦值。賦值運算子只能被過載為類的非靜態成員函式,不能過載為友元函式和普通函式。對於使用者自定義的類而言,如果沒有過載賦值運算子,那麼c 編譯器會為該類提供乙個預設的過載賦值運算子成員函式。預設賦值運算子的工作方式是按位對拷,將等到右邊物件的非靜態成員拷貝給等號左邊的物件...
C 運算子過載賦值運算子
自定義類的賦值運算子過載函式的作用與內建賦值運算子的作用類似,但是要要注意的是,它與拷貝建構函式與析構函式一樣,要注意深拷貝淺拷貝的問題,在沒有深拷貝淺拷貝的情況下,如果沒有指定預設的賦值運算子過載函式,那麼系統將會自動提供乙個賦值運算子過載函式。賦值運算子過載函式的定義與其它運算子過載函式的定義是...
C 運算子過載轉換運算子
為什麼需要轉換運算子?大家知道對於內建型別的資料我們可以通過強制轉換符的使用來轉換資料,例如 int 2.1f 自定義類也是型別,那麼自定義類的物件在很多情況下也需要支援此操作,c 提供了轉換運算子過載函式 它使得自定義類物件的強轉換成為可能。轉換運算子的生命方式比較特別,方法如下 operator...