一.前言 其实本人学习C++的目的,只是为了体会OOP设计思想,并为利用System Verilog验证复杂设计做准备.如果想要真正做点软件方面项目级的东西,还需要掌握其他高级语言和库.框架等知识.因此该系列博文仅注重语言基础和设计思想.上一篇该系列博文讲述了C++中基本的类封装,这次利用运算符重载友元函数来体会下C++的灵活性. 二.运算符重载友元函数  本文同样以<C++ Primer Plus>中的一个简单示例来讲解此内容.场景如下:时间粗劣地分为时和分两部分.需要完成两个时间的相加.时…
C++ 运算符重载和函数重载 C++ 允许在同一作用域中的某个函数和运算符指定多个定义,分别称为函数重载和运算符重载. 重载声明是指一个与之前已经在该作用域内声明过的函数或方法具有相同名称的声明,但是它们的参数列表和定义(实现)不相同. 函数重载 在同一个作用域内,可以声明几个功能类似的同名函数,但是这些同名函数的形式参数(指参数的个数.类型或者顺序)必须不同.不能仅通过返回类型的不同来重载函数. 下面的实例中,同名函数 print() 被用于输出不同的数据类型: #include <iostr…
友元是一种定义在类外部的普通函数或类,但它须要在类体内进行说明,为了与该类的成员函数加以差别,在说明时前面加以keywordfriend. 友元不是成员函数,可是它能够訪问类中的私有成员. 友元的作用在于提高程序的执行效率.可是,它破坏了类的封装性和隐藏性,使得非成员函数能够訪问类的私有成员. 有两种形式的友元: (1)友元函数:普通函数对一个訪问某个类中的私有或保护成员. (2)友元类:类A中的成员函数訪问类B中的私有或保护成员. 友元函数: 在类声明的不论什么区域中声明,而定义则在类的外部.…
方法 重载 调用 __init__ 构造函数 x = Class() __del__ 析构函数 del x __str__ 打印 print x __call__ 调用函数 x(*args) __getattr__ 获取属性 y = x.method __setattr__ 设置属性 x.any = value __getitem__ 获取索引 x[key] __setitem__ 设置新索引 x[key] = value __len__ 长度 len(x) __iter__ 迭代 for it…
我们知道,C++中的运算符重载有两种形式:①重载为类的成员函数(见C++运算符重载(成员函数方式)),②重载为类的友元函数. 当重载友元函数时,将没有隐含的参数this指针.这样,对双目运算符,友元函数有2个参数,对单目运算符,友元函数有一个参数.但是,有些运行符不能重载为友元函数,它们是:=,(),[]和->. 重载为友元函数的运算符重载函数的定义格式如下: friend 函数类型 operator 运算符(形参表) { 函数体; } 一.程序实例 //运算符重载:友元函数方式 #includ…
5.2.5 "++"和"--"的重载 对于前缀方式++ob,可以用运算符函数重载为: ob.operator++() //成员函数重载 或 operator++(X &ob) //友元函数重载,其中ob为类X的对象的引用 对于后缀方式++ob,可以用运算符函数重载为: ob.operator++(int) //成员函数重载 或 operator++(X &ob,int) //友元函数重载,其中ob为类X的对象的引用 调用时,参数int一般被传递给值0…
//类模版与友元函数 #include<iostream> using namespace std; template<typename T> class Complex{ public: Complex(T a,T b); void Print() const//const修饰的是this指针 { cout << this->Real << ":" <<this->Image<< endl; } /*…
(根据<C++程序设计>(谭浩强)整理,整理者:华科小涛,@http://www.cnblogs.com/hust-ghtao转载请注明) 对运算符重载的函数有两种处理方式:(1)把运算符重载的函数作为类的成员函数:(2)运算符重载的函数不是类的成员函数,在类中把它声明为友元函数. 1    把运算符重载函数作为类的成员函数 在上一篇博客(http://www.cnblogs.com/hust-ghtao/p/3525522.html)中,运算符重载函数 operator + 就是属于这种形式…
运算符重载的意义是:将常见的运算符重载出其他的含义:比如将*重载出指针的含义,将<<与cout联合使用重载出输出的含义,但需要认识到的问题是:运算符的重载:本质仍然是成员函数,即你可以认为:发生运算符重载时,实际上,是调用了成员函数,只不过重新换了个名字,叫运算符重载. 友元函数的意义:使得我们能够像成员函数一样访问私有成员变量,不会受到“权限”.下面通过一个函数来认识这一点: # ifndef MYTIME3_H_H # define MYTIME3_H_H # include "…
首先,介绍三种重载方式: //作为成员函数重载(常见) class Person{ Private: string name; int age; public: Person(const char* name, int age):name(name),age(age){} bool operator<(const Person& b); }; bool Person::operator<(const Person& b) { //作为成员函数时,*this即为左操作数a ...…