c++11对构造函数多过一个参数用explicit

本文介绍了C++中的explicit关键字,用于防止构造函数的隐式转换。通过示例展示了在C++11之前的版本以及C++11之后,explicit如何影响多参数构造函数的行为。同时,讨论了其在函数参数传递中的应用,以及在不同编译器中的表现差异。
摘要由CSDN通过智能技术生成

explicit

这个关键字在C++1.0(C++11之前)就已经有了。但C++11提出, explicit for actors taking more than one argument。
例子1:(这个例子不太符合explicit)

#include <iostream>

using namespace std;

class P
{
public:
    P(int a, int b)
    {
        cout << "P(int a, int b)" << endl;
    }
    P(initializer_list<int>)
    {
        cout << "P(initializer_list<int>)" << endl;
    }
     explicit P(int a, int b, int c)
    {
        cout << "explicit P(int a, int b, int c)" << endl;
    }
};
void fp(const P&)
{

}
    P p1(77, 5); //P(int a, int b)
    P p2{ 77,5 }; //P(initializer_list<int>)

    P p3{ 77,5,42 };//P(initializer_list<int>)

    P p4 = { 77, 5};//P(initializer_list<int>)
    P p5 = { 77,5,42 };//P(initializer_list<int>),理论上是会报错的,但我在VS2017和qt5.9中可以编译过
    P p6(77, 5, 42);//explicit P(int a, int b, int c)

    cout << "---------------------------" << endl;
    fp({ 47,11 });//P(initializer_list<int>)
    fp({ 47,11,3 });//P(initializer_list<int>),理论上是会报错的,但我在VS2017和qt5.9中可以编译过
    fp(P{ 47,11 });//P(initializer_list<int>)
    fp(P{ 47,11,3 });//P(initializer_list<int>)
    cout << "---------------------------" << endl;
    P p11{ 77,5,42,500 };//P(initializer_list<int>)
    P p12 = { 77, 5, 42, 500 };//P(initializer_list<int>)
    P p13{ 10 };//P(initializer_list<int>)

    cout<<__cplusplus<<endl;//201103
    return 0;
    

例子2:

#include <iostream>

using namespace std;

class Complex
{
private:
    int real{};
    int imag{};
public:
    explicit //不加这个关键字下面不报错,加了就报错,信息如下图
    Complex(int re, int im=0):real(re),imag(im)
    {

    }
    Complex operator +(const Complex& x)
    {
        return Complex((real+x.real),(imag+x.imag));
    }
};

int main()
{

    Complex c1(12,5);
   //! Complex c2 = c1+5;  //error
}

出错原因:
在这里插入图片描述

explicit的作用

explicit的英文解释是明白的、明确的,不要让编译器给我自作主张进行隐式转换。一般只有构造函数才会用上这个关键字。

 //! Complex c2 = c1+5;  //error

这里如果构造函数不加explicit的话可以编译通过,是因为编译看5会想办法看能不能把5变成5+0i这样的复数。而加上explicit会报错是因为我们明确对拒绝了这种隐式转换。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 我可以解释explicit构造函数的用法。 explicit构造函数C++中的一种特殊构造函数,它可以防止类的实例被隐式转换,从而避免出现错误。它通常被定义为一个具有const限定符的成员函数,这意味着它不能修改类的成员变量。 ### 回答2: 在C++中,构造函数被用于创建对象并初始化其成员变量。然而,有时我们可能希望禁止隐式地将某个类的一个参数类型转换为该类的对象类型,这时就可以使用explicit关键字来声明构造函数。 当我们使用explicit关键字声明一个构造函数时,它将不再能够进行隐式类型转换。只有在显式地调用构造函数时,才能使用该构造函数创建一个对象。 explicit关键字的使用可以避免一些潜在的问题和错误的发生。它可以防止编译器隐式地将一个参数类型转换为对象类型,以免引发意想不到的结果。 举个例子,假设有一个类A,其中有一个带有一个int参数构造函数。如果我们不使用explicit关键字来声明该构造函数,那么在编译器看来,一个int类型的变量可以被自动转换为一个A类型的对象。这种隐式转换可能会导致意想不到的结果和错误的发生。 但是如果我们使用explicit关键字来声明该构造函数,那么编译器将不再允许隐式转换,只能通过显式调用构造函数来创建对象。 总之,explicit关键字用于禁止隐式地将一个参数类型转换为对象类型。它可以避免潜在的问题和错误,使代码更加可靠和健壮。 ### 回答3: 在C++中,构造函数(Constructor)是一种特殊类型的成员函数,用于在创建对象时初始化对象的数据成员。当我们定义一个类时,可以定义一个多个构造函数来满足不同的对象创建需求。其中,explicit一个关键字,用于修饰构造函数explicit关键字的作用是防止隐式转换,它只能用于单参构造函数(即只有一个参数构造函数)。当构造函数声明为explicit时,禁止编译器通过隐式转换将该参数类型转换成对应的类类型。可以通过显式方式调用构造函数进行对象的创建和转换。 举个例子,假设有一个类A,其中定义了一个单参构造函数A(int n),同时使用了explicit关键字进行修饰。如果没有explicit关键字修饰,则可以进行隐式转换,比如可以使用A对象去初始化一个int类型的变量。但是,如果使用explicit修饰之后,编译器将不再允许隐式转换,只能通过显式方式进行构造和转换。 这种explicit用法可以避免一些不必要的类型转换带来的错误和混淆,能够增加程序的类型安全性。此外,explicit关键字还可以用于拒绝编译器进行多次隐式转换,因为如果构造函数没有使用explicit关键字修饰,编译器可能会进行多次自动类型转换,导致程序的行为变得复杂和难以理解。 总结来说,当我们在定义构造函数时,如果希望限制使用隐式转换创建对象的情况,就可以使用explicit关键字对构造函数进行修饰,以保证程序的可读性和类型安全性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

困了就喝白茶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值