加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C++的explicit的作用与隐式转化

发布时间:2020-12-15 04:46:49 所属栏目:百科 来源:网络整理
导读:了解explicit之前,要先弄清楚什么是隐式转化。隐式转化既是当构造器只有一个参数时或有多个默认参数时,可以直接用 “ = ”直接赋值。如下: #include "pch.h" #include #include #include "malloc.h" using namespace std; class A { public: A(int a = 5)

了解explicit之前,要先弄清楚什么是隐式转化。隐式转化既是当构造器只有一个参数时或有多个默认参数时,可以直接用 “ = ”直接赋值。如下:

#include "pch.h"

#include

#include

#include "malloc.h"

using namespace std;

class A

{

public:

A(int a = 5) { this->a = a; };

int getA() { return a; };

private:

int a;

};

int main()

{

A s;

s = 20; //可以直接对s的唯一参数进行修改。

cout << "s.a = " << s.getA() << endl;

return EXIT_SUCCESS;

}

但是当多个参数的构造器时,这样的隐式转化只会对第一个进行修改,这就出现了一些歧义。

#include "pch.h"

#include

#include

#include "malloc.h"

using namespace std;

class A

{

public:

A(char c = 'a',int a = 5): c(c),a(a) {};

int getA() { return a; };

char getC() { return c; };

private:

char c;

int a;

};

int main()

{

A s;

s = 'd';

s = 120;//就是ASCII码的 x

cout << "s.c = " << s.getC() << endl;

cout << "s.a = " << s.getA() << endl;

return EXIT_SUCCESS;

}

结果就只有c变为x。

所以用explicit修饰构造器,编译器就会避免这种隐式转化。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读