C++类和对象(4):运算符重载——=、==、()函数调用运算符

本文详细介绍了C++中赋值运算符和关系运算符的重载方法,包括解决深浅拷贝问题及如何实现自定义类型的比较。此外,还讲解了函数调用运算符的重载,通过实例演示了仿函数的使用。

赋值运算符重载:

在这里插入图片描述
注意第四点:C++编译器自动生成复制运算符operator=,对属性进行值拷贝;

如果类中有属性指向堆区,做赋值操作时也会出现深浅拷贝问题;

P1 = p2;

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

重载赋值运算符的一个重要原因是在堆区开辟了存储空间;但是赋值的过程中只是进行了浅拷贝(并未再在堆区开辟空间),所以导致堆区的数据重复释放报错;
在这里插入图片描述

int a=10,b = 20, c = 30;
a = b = c;
p1 = p2 = p3;

为了解决上述问题,所以重载赋值运算函数要放回引用类型;

关系运算符重载:

作用:重载关系运算符,可以让两个自定义类型对象进行对比操作;

	class Person {
public:
	bool operator==(Person &p) {
		if (this->age == p.age&&this->sex == p.sex) {
			return true;
		}
		return false;
	}
	Person(int age,string sex) {
		this->age = age;
		this->sex = sex;
	}
private:
	int age;
	string sex;
};
int main() {
	Person p1(18, "李四");
	Person p2(18,"王五");
	if (p1 == p2) {
		cout << "这两个人的年龄和名字相符;"<<endl;
	}
	else {
		cout << "这两个人的年龄和名字不相符;"<<endl;
	}
	system("pause");	//暂停一下以便查看
	return 0;	//标准的返回退出
 }

重载"==“和”!="相似;

函数调用运算符重载

  • 函数调用运算符 () 也可以重载
  • 由于重载后使用的方式非常像函数的调用,因此称为仿函数
  • 仿函数没有固定写法,非常灵活
class MyPrint {
public:
	void operator()(string text) {
		cout << text << endl;
	}
};
class MyAdd {
public:
	int operator()(int a, int b) {
		return a + b;
	}
};
int main() {
	MyPrint print;
	print("加油");
	MyAdd add;
	int sum = add(100, 50);
	cout << "sum = "<<sum << endl;
	
	匿名函数对象——MyPrint()MyAdd()
	//cout << MyPrint()("你好啊!") << endl;————因为没有返回值,所以没有输出不能使用
	cout << MyAdd()(10, 20) << endl;

	return 0;	//标准的返回退出
 }

注:可以使用匿名对象进行调用;

### Three.jsWebGL 学习难易程度 WebGL 原生 API 属于较低级别的接口,涉及复杂的数学运算和图形学原理。学习者不仅需要掌握 JavaScript 编程技能,还需具备矩阵变换、着色器编程等方面的知识才能有效利用此技术构建交互式的3D内容[^1]。 相比之下,Three.jsWebGL 进行了高层次抽象封装,极大降低了初学者进入该领域的障碍。只要求使用者拥有基本的JavaScript能力以及HTML/CSS方面的经验即可快速上手创建简单的3D对象并将其渲染到网页之中。通过提供丰富的内置函数和支持多种加载模型的方式,Three.js 让开发者可以更专注于创意表达而非底层细节处理。 因此,在比较两者的学习曲线时,显然基于Three.js 开发更加容易入手,并且随着实践深入也更容易获得成就感,这对于激发持续学习的兴趣十分有利。而对于那些希望深入了解GPU工作原理或是追求极致性能优化的人而言,则可能更适合先从研究WebGL本身开始。 ```javascript // 使用Three.js 创建一个旋转立方体的例子 import * as THREE from 'three'; const scene = new THREE.Scene(); const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000); const renderer = new THREE.WebGLRenderer(); renderer.setSize(window.innerWidth, window.innerHeight); document.body.appendChild(renderer.domElement); const geometry = new THREE.BoxGeometry(); const material = new THREE.MeshBasicMaterial({ color: 0x00ff00 }); const cube = new THREE.Mesh(geometry, material); scene.add(cube); camera.position.z = 5; function animate() { requestAnimationFrame(animate); // 使立方体自转 cube.rotation.x += 0.01; cube.rotation.y += 0.01; renderer.render(scene, camera); } animate(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值