【c++深度解析7】隐式类型转换二

本文深入探讨C++中转换构造函数的概念与使用,解析如何通过单参数构造函数实现类型转换,及其可能带来的隐式转换问题。通过实例代码,演示了如何使用explicit关键字避免不必要的类型转换,以及几种常见的转换方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转换构造函数:参数满足如下条件时的构造函数为转换构造函数:

1.有且仅有一个参数

2.参数是基本类型

3.参数是其他类型

下面看下如下的代码:

#include <iostream>
#include <string>

using namespace std;

class Test
{
    int mValue;
public:
    Test()
    {
        mValue = 0;
    }
    
    Test(int i)
    {
        mValue = i;
    }
    
    Test operator + (const Test& p)
    {
        Test ret(mValue + p.mValue);
        
        return ret;
    }
    
    int value()
    {
        return mValue;
    }
};

int main()
{   
    Test t;
    
    
    t = 5;    // 1。会编译过吗发生了什么
    
    
    
    Test r;
    
    r = t + 10;   // / 2。会编译过吗发生了什么
    
    cout << r.value() << endl;
    
    return 0;
}

 

通过运行发现:

  t = 5;    // 1。会编译过吗发生了什么   编译通过,发生了隐式类型转换  调用了     Test(int i) 这个构造函数

实际等价于 t = Test(5)

  r = t + 10;   // / 2。会编译过吗发生了什么  编译通过 ,发生了隐式类型转换 调用了  Test(int i) 这个构造函数 然后调用Test operator + (const Test& p) 这个操作符重载函数  实际上等价于  t  = t + Test(10)

上面隐式类型转换很隐蔽,很容易引入bug   怎样避免编译器自己进行不必要的隐式类型转换了  

通过 explicit 关键字 杜绝编译器的转换尝试,只能让其进行显示转换;

转换方式如下:

static_cast<ClassName> (value)

ClassName(value);

(ClassName) value ;//  不推荐方式

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值