C++中explicit关键字用法

在C++类的实例化过程中,存在一种隐式转换,即可以用单个实参来调用的构造函数定义了从形参类型到该类类型的一个隐式转换


一个简单的例子:

#include <iostream>
#include <string>

using namespace std;

class Book
{
public:
	Book(){}
	Book(const string name, const int price = 100) : _name(name), _price(price){
		cout << "构造函数调用!" << endl;;
	};

	void IsSameBook(const Book & book)
	{
		if (_name == book._name)
			cout << "两本书重名!" << endl;
		else
			cout << "两本书不重名!" << endl;
	}
private:
	string _name;
	int _price;
};

void main()
{
	Book A("AA");	
	A.IsSameBook(string("AA"));	
	system("Pause");
}


执行输出:

构造函数调用!
构造函数调用!
两本书重名!


这里的第一次构造函数调用是声明Book类的实例A,第二次构造函数调用是因为用 string类型的 “AA”作为IsSameBook函数的形参,这个函数本来的形参应该是一个Book的类对象,而类Book又满足构造函数只含有一个未初始化的形参的条件(可以含有多个已经有初始化值的形参),所以这里编译器就默认执行了一次隐式转换,把“AA”作为形参,实例化了一个Book类的临时对象object,这样,对象A就和这个object对象判断名字是否一样,从而有了两本书重名的判断。这个临时object对象在函数结束的时候就销毁了。


为了防止这种意料之外的隐式转换,在类的构造函数前加上explicit关键字,可以防止形参隐式转换为该类类型的转换:

#include <iostream>
#include <string>

using namespace std;

class Book
{
public:
	Book(){}
	explicit Book(const string name, const int price = 100) : _name(name), _price(price){
		cout << "构造函数调用!" << endl;;
	};

	void IsSameBook(const Book & book)
	{
		if (_name == book._name)
			cout << "两本书重名!" << endl;
		else
			cout << "两本书不重名!" << endl;
	}
private:
	string _name;
	int _price;
};

void main()
{
	Book A("AA");	
	Book B = Book("AA");
	A.IsSameBook(B);	
	system("Pause");
}

构造函数加上explicit关键字之后,使用A.IsSameBook(string("AA"))的写法,编译器会报错。explicit的作用就是防止其他类型对该类类型的隐式转换,但仍可以以显示转换的方式调用, 如 Book B=Book("AA")的写法。


  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值