C++ 学习系列 -- conversion function

一 什么是转换函数?

在 c++ 编码中,我们可能遇到要将类 A 转为 类 B 的情况,此时就可以定义类 A 的转换函数将其按照一定规则转换为 类 B;

转换函数声明规则如下:

cpp 复制代码
operator 转换类型() const;

转换函数无返回值,转换类型是一个已定义的类,包括c++基本类型 int、double 等,也包括事先定义过的类。

这里介绍一下隐式转换的知识点:

所谓隐式转换,由编译器私下进行的类型转换,该转换不需要使用者干预。

当一个值拷贝给另外一个兼容类型的值时, 往往会发生自动转换

cpp 复制代码
int a = 3;

double b = 4.5;

double c = a + b; // a将会被自动转换为double类型,转换的结果和b进行加法操作

二 例子

1. 转换函数

cpp 复制代码
// fraction.h
class Fraction
{
public:
     Fraction(int num, int den = 1):m_numerator(num), m_denominator(den)
    {

    }
    ~Fraction(){ }

    // 转换函数
    operator double() const
    {
        return (double)m_numerator / m_denominator;
    }

private:
    int m_numerator; // 分子
    int m_denominator; // 分母
};

// main.cpp
#include<iostream>

int main()
{
   Fraction f(5, 10);
   double re1 = 1 + f; // 编译器编译到这里时,会尝试去寻找编译通过的方法,类的转换函数就是其中一种方法, 当发现 Fraction 没有 operator+(Fraction) 重载函数,但是有转换函数时,编译是可以通过的
   std::cout << re1 << std::endl;

   return 0;
}

输出:

1.5

2. 隐式转换

cpp 复制代码
// fraction.h

class Fraction
{
public:
     Fraction(int num, int den = 1):m_numerator(num), m_denominator(den)
    {

    }
    ~Fraction(){ }

    // 自定义 operator + 符合函数
    Fraction& operator+(const Fraction& other)
    {
        this->m_numerator = this->m_numerator * other.m_denominator + other.m_numerator * this->m_denominator;
        this->m_denominator = other.m_denominator * this->m_denominator;
        return *this;
    }

public:
    int m_numerator; // 分子
    int m_denominator; // 分母
};

// main.cpp
#include<iostream>

int main()
{
   Fraction f(5, 10);
   Fraction f2 = f + 3; // 编译器利用构造函数 将 3 隐式转换为 Fraction
   std::cout << f.m_numerator << ", " << f.m_denominator << std::endl;
   
   return 0;
}

输出:

35, 10

3. 禁用隐式转换

explicit 关键字修饰构造函数后,则禁止编译器私自做隐式转换

cpp 复制代码
// faraction.h
class Fraction
{
public:
    // explicit 关键字修饰构造函数后,禁止编译器私自做隐式转换
    explicit Fraction(int num, int den = 1):m_numerator(num), m_denominator(den)
    {

    }
    ~Fraction(){ }


    Fraction& operator+(const Fraction& other)
    {
        this->m_numerator = this->m_numerator * other.m_denominator + other.m_numerator * this->m_denominator;
        this->m_denominator = other.m_denominator * this->m_denominator;
        return *this;
    }

public:
    int m_numerator; // 分子
    int m_denominator; // 分母
};

// main.cpp
#include<iostream>

int main()
{
   Fraction f(5, 10);
   Fraction f2 = f + 3; // 因为禁用了隐式转换,因此无法编译通过
   std::cout << f.m_numerator << ", " << f.m_denominator << std::endl;

   return 0;
}
相关推荐
ASKED_201910 分钟前
Langchain学习笔记一 -基础模块以及架构概览
笔记·学习·langchain
(❁´◡`❁)Jimmy(❁´◡`❁)1 小时前
Exgcd 学习笔记
笔记·学习·算法
云小逸2 小时前
【nmap源码学习】 Nmap网络扫描工具深度解析:从基础参数到核心扫描逻辑
网络·数据库·学习
盐焗西兰花5 小时前
鸿蒙学习实战之路-Reader Kit构建阅读器最佳实践
学习·华为·harmonyos
深蓝海拓5 小时前
PySide6从0开始学习的笔记(二十七) 日志管理
笔记·python·学习·pyqt
慎独4135 小时前
科学赋能,让孩子专注高效爱上学习
学习
LGL6030A5 小时前
Java学习历程26——线程安全
java·开发语言·学习
学历真的很重要6 小时前
【系统架构师】第二章 操作系统知识 - 第二部分:进程管理(详解版)
学习·职场和发展·系统架构·系统架构师
Nebula_g6 小时前
线程进阶: 无人机自动防空平台开发教程(更新)
java·开发语言·数据结构·学习·算法·无人机
星期五不见面7 小时前
机器人学习!(二)ROS2-节点(7)2026/02/03
学习