C++:多态之重载

简介:     在C++中,有两种重载,一种是函数的重载,另一种是运算符的重载。     C++的重载最早出现在基本运算符上。例如,加法操作只有一个运算符+,但是它却可以实现整数,浮点数,指针的加法运算。

    在C++中,有两种重载,一种是函数的重载,另一种是运算符的重载。

    C++的重载最早出现在基本运算符上。例如,加法操作只有一个运算符+,但是它却可以实现整数,浮点数,指针的加法运算。函数的重载与运算符的重载实现的效果一样,都是一种东西,实现相似的功能,只是在调用时,使用的参数的个数或类型上有不同。

    函数的重载

  如下,定义了4个函数,它们的名字都是:myMax(),但是,其中的参数各不相同,在调用函数时,通过判断函数中所给的参数的个数和类型来判断调用的是哪一个函数。


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

int myMax(int x,int y);	//比较两个整数
char myMax(char first,char second);	//比较两个字符
double myMax(double u,double v);  //比较两个小数
char * myMax(char * frist,char * second);   //比较两个字符串

int main()  //主函数
{
	cout<<"in 3 and 5,the max number is "<<myMax(3,5)<<endl;  //调用比较整数的函数
	cout<<"in c and t the max char is:"<<myMax('c','t')<<endl;   //调用比较字符的函数
	cout<<"in 3.1 and -5.3,the max double number is:"<<myMax(3.1,-5.3)<<endl;  //调用比较浮点数的函数
	cout<<"in what and where the max string is:"<<myMax("what","where")<<endl;  //调用比较字符的函数

}


//下面为函数体

int myMax(int x,int y)  //比较两个整数
{
	if(x>y) return x;
	else return y;
}

char myMax(char first,char second)  //比较两个字符
{
	if(first>second) return first;
	else return second;

}

double myMax(double u,double v)  //比较两个小数
{
	if(u>v) return u;
	else return v;
}

char * myMax(char * first,char * second)   //比较两个字符串
{
	if(strcmp(first,second)>0) return first;
	else return second;

}

  


运行的结果如下:



  在函数重载时一定要注意的是:函数重载至少要在参数个数或参数类型上有所不同,否则在调用时,编译器无法区分到底调用的是哪个函数。


运算符的重载

运算符重载运行把标准运算符如:+ ,-,*,<等应用于定制数据类型的对象.为此,要编写一个函数,重新定义运算符,来说明重载后的运算符是如何使用的,起到什么作用.

 

重载给定运算符的函数名由关键字operator和要重载的运算符组成。

 

    例如:现在需要一个空间三维点坐标相加的操作,需要重写+运算符,来实现两点直接相加。

  

#include<iostream>
using namespace std;

class Point   //定义三维空间中的一个点
{
public:

	Point(int i,int j,int k):x(i),y(j),z(k) {};   //点的构造函数
	
	int x,y,z;
	
	Point operator + (Point p2)   //定义两个点相加的操作
	{
		x+=p2.x;
		y+=p2.y;
		z+=p2.z;

		return Point(x,y,z);
	}
	
};

int main()
{
	Point P1(1,2,3);
	Point P2(4,5,6);
	Point P3(0,0,0);

	P3=P1+P2;  //将两个点相加,结果保存到P3中
	
	cout<<P3.x<<endl;
	cout<<P3.y<<endl;
	cout<<P3.z<<endl;
	
return 0;
	
}

结果如下:

  


在上面的程序中,重写了+这个运算符,其中,参数只有一个点,因为这里返回的x,y,z,在实际运行时,是隐含了this指针的,所以运行结果实际是保存在了P1中。


  

目录
相关文章
|
1月前
|
编译器 C++
C++入门12——详解多态1
C++入门12——详解多态1
36 2
C++入门12——详解多态1
|
1月前
|
C++
C++入门13——详解多态2
C++入门13——详解多态2
79 1
|
2月前
|
C++
C++(十九)new/delete 重载
本文介绍了C++中`operator new/delete`重载的使用方法,并通过示例代码展示了如何自定义内存分配与释放的行为。重载`new`和`delete`可以实现内存的精细控制,而`new[]`和`delete[]`则用于处理数组的内存管理。不当使用可能导致内存泄漏或错误释放。
|
3月前
|
存储 编译器 C++
|
4月前
|
存储 编译器 C++
【C++】深度解剖多态(下)
【C++】深度解剖多态(下)
53 1
【C++】深度解剖多态(下)
|
4月前
|
存储 编译器 C++
|
3月前
|
存储 编译器 C++
C++多态实现的原理:深入探索与实战应用
【8月更文挑战第21天】在C++的浩瀚宇宙中,多态性(Polymorphism)无疑是一颗璀璨的星辰,它赋予了程序高度的灵活性和可扩展性。多态允许我们通过基类指针或引用来调用派生类的成员函数,而具体调用哪个函数则取决于指针或引用所指向的对象的实际类型。本文将深入探讨C++多态实现的原理,并结合工作学习中的实际案例,分享其技术干货。
71 0
|
4月前
|
机器学习/深度学习 算法 C++
C++多态崩溃问题之为什么在计算梯度下降时需要除以批次大小(batch size)
C++多态崩溃问题之为什么在计算梯度下降时需要除以批次大小(batch size)
|
4月前
|
NoSQL 编译器 Redis
c++开发redis module问题之如果Redis加载了多个C++编写的模块,并且它们都重载了operator new,会有什么影响
c++开发redis module问题之如果Redis加载了多个C++编写的模块,并且它们都重载了operator new,会有什么影响
|
4月前
|
Java 编译器 C++
【C++】深度解剖多态(上)
【C++】深度解剖多态(上)
52 2