news 2026/6/10 16:22:23

3.其他重载运算符

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
3.其他重载运算符

3.其他重载运算符

重载+, -, *

mytime2.h

#ifndef __MYTIME2_H__ #define __MYTIME2_H__ ​ #include <iostream> ​ using namespace std; ​ class Time { private: int hours; int minutes; public: Time(); Time(int h, int m = 0); void AddMin(int m); void AddHr(int h); void Reset(int h = 0, int m = 0); Time operator+(const Time &t) const; Time operator-(const Time &t) const; Time operator*(double mult) const; void Show() const; }; ​ #endif ​

mytime2.cpp

#include "mytime2.h" ​ Time::Time() { hours = minutes = 0; } ​ Time::Time(int h, int m) { hours = h; minutes = m; } ​ void Time::AddMin(int m) { minutes += m; hours += minutes / 60; minutes %= 60; } ​ void Time::AddHr(int h) { hours += h; } ​ void Time::Reset(int h, int m) { hours = h; minutes = m; } ​ Time Time::operator+(const Time &t) const { Time sum; ​ sum.minutes = minutes + t.minutes; sum.hours = hours + t.hours + sum.minutes / 60; sum.minutes %= 60; ​ return sum; } ​ Time Time::operator-(const Time &t) const { Time diff; ​ int tot1, tot2; tot1 = hours * 60 + minutes; tot2 = t.hours * 60 + t.minutes; diff.hours = (tot1 - tot2) / 60; diff.minutes = (tot1 - tot2) % 60; ​ return diff; } ​ Time Time::operator*(double mult) const { Time result; ​ long totalminutes = hours*mult*60 + minutes*mult; result.hours = totalminutes / 60; result.minutes = totalminutes % 60; ​ return result; } ​ void Time::Show() const { cout << hours << " hours, " << minutes << " minutes." << endl; } ​

usetime2.cpp

#include <iostream> #include "mytime2.h" ​ using namespace std; ​ int main(void) { Time coding(4, 35); Time fixing(2, 47); Time total; Time Planning; Time diff; Time adjusted; ​ cout << "coding time = "; coding.Show(); ​ cout << "fixing time = "; fixing.Show(); ​ total = coding + fixing; total.Show(); ​ diff = coding - fixing; diff.Show(); ​ adjusted = coding * 1.5;//左侧的操作数应是调用对象,coding需要在1.5前面 adjusted.Show(); ​ return 0; } ​

.

加法和减法运算符都结合两个Time 值,而乘法运算符将一个 Time 值与一个 double值结合在一起。这限制了该运算符的使用方式。记住,左侧的操作数是调用对象。也就是说,下面的语句:A=B * 2.75; 将被转换为下面的成员函数调用: A=B.operator * (2.75); 但下面的语句又如何呢? A=2.75 * B;//cannot correspond to a member function 从概念上说,2.75 * B应与B*2.75相同,但第一个表达式不对应于成员函数,因为 2.75不是 Time 类型的对象。记住,左侧的操作数应是调用对象,但2.75不是对象。因此,编译器不能使用成员函数调用来替换该表达式。

友元函数解决非成员函数不能直接访问类的私有数据

//创建友元函数的第一步是将其原型放在类声明中,并在原型声明前加上关键字friend: friend Time operator*(double m,const Time &t);//goes in class declaration

该原型意味着下面两点: 1.虽然 operator *()函数是在类声明中声明的,但它不是成员函数,因此不能使用成员运算符来调用;

2.虽然 operator *()函数不是成员函数,但它与成员函数的访问权限相同。

第二步是编写函数定义。因为它不是成员函数,所以不要使用Time限定符。另外,不要在定义中使用关键字friend。

将来在写非成员函数的时候,可以将其写成友元函数。

友元函数重载 *

mytime2.h

#ifndef __MYTIME3_H__ #define __MYTIME3_H__ ​ #include <iostream> ​ using namespace std; ​ class Time { private: int hours; int minutes; public: Time(); Time(int h, int m = 0); void AddMin(int m); void AddHr(int h); void Reset(int h = 0, int m = 0); Time operator+(const Time &t) const; Time operator-(const Time &t) const; Time operator*(double mult) const; friend Time operator*(double mult, const Time &t);//友元函数重载 * void Show() const; }; ​ //Time operator*(double m, const Time &t);//定义成一个普通的函数,无法使用类中的private。 ​ #endif ​

mytime2.cpp

#include "mytime3.h" ​ Time::Time() { hours = minutes = 0; } ​ Time::Time(int h, int m) { hours = h; minutes = m; } ​ void Time::AddMin(int m) { minutes += m; hours += minutes / 60; minutes %= 60; } ​ void Time::AddHr(int h) { hours += h; } ​ void Time::Reset(int h, int m) { hours = h; minutes = m; } ​ Time Time::operator+(const Time &t) const { Time sum; ​ sum.minutes = minutes + t.minutes; sum.hours = hours + t.hours + sum.minutes / 60; sum.minutes %= 60; ​ return sum; } ​ Time Time::operator-(const Time &t) const { Time diff; ​ int tot1, tot2; tot1 = hours * 60 + minutes; tot2 = t.hours * 60 + t.minutes; diff.hours = (tot1 - tot2) / 60; diff.minutes = (tot1 - tot2) % 60; ​ return diff; } ​ Time Time::operator*(double mult) const { Time result; ​ long totalminutes = hours*mult*60 + minutes*mult; result.hours = totalminutes / 60; result.minutes = totalminutes % 60; ​ return result; } ​ void Time::Show() const { cout << hours << " hours, " << minutes << " minutes." << endl; } ​ //友元函数重载 * Time operator*(double mult, const Time &t) { Time result; ​ long totalminutes = t.hours*mult*60 + t.minutes*mult; result.hours = totalminutes / 60; result.minutes = totalminutes % 60; ​ return result; } ​ /* Time operator*(double mult, const Time &t) { return t * mult; } */ ​

usetime2.cpp

#include <iostream> #include "mytime3.h" ​ using namespace std; ​ int main(void) { Time coding(4, 35); Time fixing(2, 47); Time total; Time Planning; Time diff; Time adjusted; ​ cout << "coding time = "; coding.Show(); ​ cout << "fixing time = "; fixing.Show(); ​ total = coding + fixing; total.Show(); ​ diff = coding - fixing; diff.Show(); ​ adjusted = coding * 1.5; adjusted.Show(); ​ adjusted = 1.5 * coding;//友元函数重载 *, 等价于operator*(1.5, coding) adjusted.Show(); ​ return 0; } ​

.

Time Time::operator*(double mult) constfriend Time operator*(double mult, const Time &t)这两个重载*的函数有什么区别?


✅ 一句话总结:

一个是成员函数,只能写成t * 2.0; 一个是友元函数,支持2.0 * t这种写法。


🔍 详细对比:

特性成员函数版本友元函数版本
定义方式Time Time::operator*(double mult) constfriend Time operator*(double m, const Time &t)
调用方式time * 2.02.0 * time
参数个数1 个显式参数(this是隐式参数)2 个显式参数
访问私有成员✅ 可以(因为是成员)✅ 可以(因为是友元)
是否支持交换律❌ 不支持(只能time * 2.0✅ 支持(可以2.0 * time

✅ 举个例子:

Time t(1, 30); // 1小时30分钟 ​ Time a = t * 2.0; // ✅ 成员函数版本 Time b = 2.0 * t; // ✅ 友元函数版本(没有它就不行)

✅ 总结一句话:

成员函数只能处理对象 * 数字友元函数才能处理数字 * 对象,实现真正的交换律。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 10:46:16

Easy Dataset:三分钟开启你的专属LLM微调之旅

还在为复杂的模型微调流程而苦恼吗&#xff1f;面对海量文档、繁琐的数据预处理&#xff0c;是否渴望有一款工具能让你专注于核心业务&#xff1f;Easy Dataset正是为简化LLM微调而生的智能助手&#xff0c;让你在3分钟内完成部署&#xff0c;立即开始构建高质量微调数据集。 【…

作者头像 李华
网站建设 2026/6/10 10:46:09

React 动态显示icon

通过ant-design/icons引入Icon大对象&#xff0c;通过Icon[icon名]获取对应的对象&#xff0c;在需要添加icon的地方调用React.createElement就可以显示icon。import { Button } from "antd" import React from react import * as Icon from ant-design/icons;func…

作者头像 李华
网站建设 2026/6/10 10:43:13

42、Linux编程:软件开发工具探索

Linux编程:软件开发工具探索 1. 编程基础概念 在编程中,有一个常见的流程被称为编辑 - 编译 - 调试(Edit - Compile - Debug)循环,大多数程序员在程序正确运行之前都需要多次重复这个过程。除了了解基本的编程步骤,还需要熟悉以下术语和概念: - 变量 :用于存储不同…

作者头像 李华
网站建设 2026/6/10 9:38:37

高效SCPI解析器:开源仪器控制库的专业应用指南

高效SCPI解析器&#xff1a;开源仪器控制库的专业应用指南 【免费下载链接】scpi-parser Open Source SCPI device library 项目地址: https://gitcode.com/gh_mirrors/sc/scpi-parser 开篇引入 在嵌入式仪器控制开发中&#xff0c;工程师常常面临SCPI命令解析的复杂性…

作者头像 李华
网站建设 2026/6/9 16:46:27

【有手就行】自己花20分钟从0开始训练一个“大模型”

一、说在前面训练基座大模型那都是大公司们的事情&#xff0c;普通人、普通公司肯定是玩不起的&#xff0c;但是作为一个技术人&#xff0c;你可以不去做真正的大模型训练&#xff0c;但是你还是有必要知道和了解一下一个大模型是如何训练出来的。而GPT_teacher-3.37M-cn 是一个…

作者头像 李华
网站建设 2026/6/9 14:56:28

【VSCode量子编程避坑指南】:揭秘常见错误及高效处理策略

第一章&#xff1a;VSCode量子作业的错误处理在开发量子计算程序时&#xff0c;使用 VSCode 配合 Q# 插件进行量子作业编写已成为主流选择。然而&#xff0c;在实际运行中常会遇到编译错误、模拟器异常或资源估算失败等问题。有效识别并处理这些错误&#xff0c;是保障量子算法…

作者头像 李华