Effective C++ 第三版 [条款24:隐喻类型转换的函数应该是个non-member]

本文主要是介绍Effective C++ 第三版 [条款24:隐喻类型转换的函数应该是个non-member],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

条款24:当一个类需要类型转换时,应使用 non-member 函数

例如:一个有理数类,想支持诸如加法、乘法等,是使用member 函数,还是使用 non-member 函数,还是使用 friend non-member 函数呢?


1,使用成员函数(member function)时

#include <iostream>
using namespace std;class Rational {
public:Rational(int num = 0, int den = 1) : numerator(num), denominator(den) {}// member functionconst Rational operator*(const Rational& rhs) const {return Rational(numerator * rhs.numerator, denominator * rhs.denominator);}void print() const{cout << numerator << "/" << denominator << endl;}int getNum() const { return numerator; }int getDen() const { return denominator; }
private:int numerator;int denominator;};int main()
{Rational oe(1, 8);Rational oh(1, 2);// successRational result = oe * oh;result.print(); // (1,8) * (1,2) = (1, 16)// successresult = oe * 2;result.print(); // (1,8) * (2,1) = (2, 8)// 这里2 进行了隐性转换// Rational temp(2);>> temp(2,1)// result = oe * temp;// error// result = 2 * oe;// error C2677: 二进制“*”: 没有找到接受“Rational”类型的全局运算符(或没有可接受的转换)system("pause");return 0;
}// output
1/16
2/8
请按任意键继续. . .

2,使用非成员函数(non-member function)时

#include <iostream>
using namespace std;class Rational {
public:Rational(int num = 0, int den = 1) : numerator(num), denominator(den) {}void print() const{cout << numerator << "/" << denominator << endl;}int getNum() const { return numerator; }int getDen() const { return denominator; }
private:int numerator;int denominator;};// non-member function
const Rational operator*(const Rational& lhs, const Rational& rhs) {return Rational(lhs.getNum() * rhs.getNum(), lhs.getDen() * rhs.getDen());
}int main()
{Rational oe(1, 8);Rational oh(1, 2);// successRational result = oe * oh;result.print(); // (1,8) * (1,2) = (1, 16)// successresult = oe * 2;result.print(); // (1,8) * (2,1) = (2, 8)// 这里2 进行了隐性转换// Rational temp(2);>> temp(2,1)// result = oe * temp;// successresult = 2 * oe;result.print(); // (2,1) * (1,8) = (2, 8)// 这里2 进行了隐性转换// Rational temp(2);>> temp(2,1)// result = temp * oe;system("pause");return 0;
}// output
1/16
2/8
2/8
请按任意键继续. . .

3,友元

本例而言是否定的,


结论:

只有当参数被列于参数列内(parameter list)时,参数才会是隐式类型转换的合格参与者。
如果你需要为某个函数的所有参数(包括被this指针所指的那个隐喻参数)进行类型转换,那个这个函数必须是个non-member

这篇关于Effective C++ 第三版 [条款24:隐喻类型转换的函数应该是个non-member]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1001054

相关文章

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

C++中全局变量和局部变量的区别

《C++中全局变量和局部变量的区别》本文主要介绍了C++中全局变量和局部变量的区别,全局变量和局部变量在作用域和生命周期上有显著的区别,下面就来介绍一下,感兴趣的可以了解一下... 目录一、全局变量定义生命周期存储位置代码示例输出二、局部变量定义生命周期存储位置代码示例输出三、全局变量和局部变量的区别作用域

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每