C++学习之路——函数重载和运算符重载

C++学习之路——函数重载和运算符重载一、函数重载C++允许在同一作用域中的某个函数和运算符指定多个定义,分 别称为函数重载和运算符重载重载声明是指一个与之前已经在该作用域内声明过的函数或方法 具有相同名称的声明,但是它们的参数列表和实现不相同。当您调用一个重载函数或重载运算符时,编译器通过把您所使用的参数类型与定义中的参数类型进行比较,决定选用最合适的定义。选择最合适的重载函数或重载运算符的过程,称为重载决策。C++中的函数重…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

一、函数重载

C++允许在同一作用域中的某个函数和运算符指定多个定义,分 别称为函数重载和运算符重载

重载声明是指一个与之前已经在该作用域内声明过的函数或方法 具有相同名称的声明,但是它们的参数列表和实现不相同。当您调用一个重载函数或重载运算符时,编译器通过把您所使用的参数类型与定义中的参数类型进行比较,决定选用最合适的定义。选择最合适的重载函数或重载运算符的过程,称为重载决策。
C++中的函数重载

在同一个作用域内,可以声明几个功能类似的同名函数,但是这 些同名 函数的形式参数(指参数的个数、类型或者顺序)必须不同。 您不能仅通过返回类型的不同来重载函数。
下面的实例中,同名函数 print() 被用于输出不同的数据类型:

二、运算符重载

重载的运算符是带有特殊名称的函数,函数名是由关键字 oper ator 和其后要重载的运算符符号构成的。与其他函数一样,重载运算 符有一个返回类型和一个参数列表。
Box operator + (const Box &);

声明加法运算符用于把两个 Box 对象相加,返回最终的 Box 对象。 大多数的重载运算符可被定义为普通的非成员函数或者被定义为类成 员函数。如果我们定义上面的函数为类的非成员函数,那么我们需要 为每次操作传递两个参数,如下所示:
Box operator+(const Box&, const Box&);

可重载运算符/不可重载运算符

在这里插入图片描述

在这里插入图片描述

例题:

用一个程序实现课程中讲过之外的三种运算符重载,其中new/delete为必选项,其他两个任选。

在这里插入图片描述
代码如下:

//new delete的重载
class A { 
   
	int i;
	int j;
public:
	A() { 
    cout << "A()" << endl; }

	void *operator new(size_t size)
	{ 
   
		void *p;
		p = (void *)malloc(size);
		cout << "为对象申请字节空间为" << size << endl;
		return p;
	}
	void operator delete(void *p)
	{ 
   
		cout << "删除申请的字节空间" << endl;
		free(p);
	}


	void *operator new[](size_t size)
	{ 
   
		void *p;
		p = (void*)malloc(size);
		cout<< "为对象申请的内存单元个数" << size << endl;
		return p;
	}


		void operator delete[](void *p)
	{ 
   
		cout << "删除为申请的内存单元个数" << endl;
		free(p);
	}
};

class B
{ 
   
public:
	double a;
	B(double x)
	{ 
   
		a = x;
	}
	double operator /(B m);

};
double B::operator /(B m)
{ 
   
	double x1;
	x1 = a / m.a;
	return x1;
}

//class C
//{ 
   
//public:
// string ss;
// C(string s)
// {ss = s;}
// C &operator =(const C &);
//private:
// char *p1;
//};
//
//C &C::operator =(const C &m)
//{ 
   
// if (this==&m)
// { 
   
// return *this; //防止s=s的赋值
// }
// char *p2;
// p2 = new char[strlen(m.p1) + 1];//分配新区域 
// strcpy(p2, m.p1); //字符串复制
// delete p1;
// return *this;
//}

class D
{ 
   
public:
	double a;
	D(double x)
	{ 
   
		a = x;
	}
	double operator *(D m);

};
double D::operator *(D m)
{ 
   
	double x1;
	x1 = a * m.a;
	return x1;
}

int main()
{ 
   
	cout << "************************" << endl;
	cout << "new delete的重载" << endl;
	A *a = new A;
	delete(a);
	A *a1 = new A[10];
	delete[] a1;

	cout << "************************"<< endl;
	cout << "/的重载" << endl;
	B b1(2.6);
	B b2(3.6);
	double b3;
	b3 = b1 / b2;
	cout << "b3的值为" << b3 << endl;

	//cout << "************************" << endl;
	//cout << "=的重载" << endl;
	//C c1("边牛牛");
	//C c2("真牛");
	//c2 = c1;

	cout << "************************" << endl;
	cout << "*的重载" << endl;
	D d1(2.6);
	D d2(9.6);
	double d3;
	d3 = d1 * d2;
	cout << "d3的值为" << d3 << endl;
	return 0;
}


结果为:
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170998.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月18日 上午8:00
下一篇 2022年8月18日 上午8:00


相关推荐

  • 用shapely判断两个图形的包含相交关系

    用shapely判断两个图形的包含相交关系shapelyshape 介绍 shapely 安装 shapely 的导入 Point LineString Polygon 的通用属性 Point 对象 LineString 对象 Polygon 对象 box 对象一元判定二元判定 shapely 介绍 shapely 是专门做图形计算的包 基本上图形线段 点的判断包里都有 shapely 里主要由 Point LineString Polygon 这三类组成 在 shapely 里点 线 面之间都是可以做判断的 比如说计算点到线段的距离 点到面之间的距离 点与点之间的距离 点是否在一个图形

    2026年3月19日
    2
  • OpenClaw 自动化工作流:每天节省 3 小时的秘密

    OpenClaw 自动化工作流:每天节省 3 小时的秘密

    2026年3月13日
    3
  • Linux 内核编程总结[通俗易懂]

    Linux 内核编程总结[通俗易懂]Linux内核编程总结   从事了几年的内核编程,对内核编程有一定的经验,现总结、吐槽下,作为标记。   任何进程都有有进程的入口点,用户态的进程,其入口点是,main函数。   那么内核的入口点是什么?个人理解整个OS,运行起来就是一个进程,   内核的入口点是init进程,在这个进程中负责:   1)子进程的创建,包括内核的线程、用户态的进程。

    2022年10月8日
    4
  • JLink接口的SWD接法

    JLink接口的SWD接法下面为J-Link接口定义:仿真器端口连接目标板备注1.VCCMCU电源VCCVCC2.VCCMCU电源VCCVCC3.TRSTTRSTTestReSeT/pin4.GNDGND或悬空 5.TDITDITestDataInpin6.

    2022年5月27日
    124
  • 欧拉错信原理——错位重排

    欧拉错信原理——错位重排欧拉错信原理 错位重排错位重排是指一种比较困难理解的复杂数学模型 是伯努利和欧拉在错装信封时发现的 因此又称伯努利 欧拉装错信封问题 表述为 编号是 1 2 n 的 n 封信 装入编号为 1 2 n 的 n 个信封内 要求每封信的编号不同 问有多少种装法 对这类问题有个固定的递

    2026年3月17日
    1
  • Agora iOS SDK-开始聊天

    Agora iOS SDK-开始聊天

    2022年3月3日
    45

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号