关键字explicit详解(一)

C++Primer(英文版,第4p.461提到:

Aconstructor that can be called with a single argument defines an implicitconversion from the parameter type to the class type.

(如果一个类的构造函数只接收一个实参(argument),那么就定义了一个从形参(parameter)数据类型到类的类型的隐式转换。

参考下面的例子,并且注意后面的注释。

#include <iostream>
#include <string>
using namespace std;

class Book
{
public:
	//如果一个类的构造函数只接收一个实参(argument),那么就定义一个从形参(parameter)数据类型到类的类型
	//的隐式转换。因此,在下面的构造函数,可隐式地将string类型转换成Book类型
	Book(const string& book_name):author("Stanley B.Lippman")
	{
		this->book_name = book_name;
	}
	//same_author的形参是const Book&
	bool same_author(const Book& book)const;
private:
	string book_name;
	string author;
};

bool Book::same_author(const Book& book)const
{
	return (this->author == book.author);
}

int main(void)
{
	//定义了一本书Inside C++ Object Model,其作者是缺省的
	Book a_book("Inside C++ Object Model");

	//定义一个字符串,作为一本书的书名
	string b_book_name("C++ Primer");

	//下面这种调用方式将会产生编译错误:不能将参数1从"const char[11]"转换成"const Book&"
	//if (a_book.same_author("C++ Primer"))

	//按照常理,if中的same_author的参数应该是Book类型,
	//但在这里,我们传入了一个string类型的实参b_book_name,
	//它将会隐式调用Book类的对应的构造函数,并将其换成一个
	//临时的Book对象,这样便满足了same_author的参数要求
	if(a_book.same_author(b_book_name))
	{
		cout<<"The great 2 books are written by great Stanley B.Lippman"<<endl;
	}
	else
	{
		cout<<"Different authors for those 2 books."<<endl;
	}
	return 0;
}

下面说说explicit这个关键字的作用。

如果把上面程序中Book类的构造函数:

Book(const string&book_name) : author("Stanley B. Lippman")

改成:explicit Book(const string&book_name) : author("Stanley B. Lippman")

那么原来的程序将会出现编译错误:

“Book::same_author”: 不能将参数1 从“std::string”转换为“constBook &”

explicit关键字,将会阻止原来的隐式转换。这时如果把if(a_book.same_author(b_book_name))

改成

Bookb_book(b_book_name);

if(a_book.same_author(b_book))

就可以了。

#include <iostream>
#include <string>
using namespace std;

class Book
{
public:
	//如果一个类的构造函数只接收一个实参(argument),那么就定义一个从形参(parameter)数据类型到类的类型
	//的隐式转换。因此,在下面的构造函数,可隐式地将string类型转换成Book类型
	explicit Book(const string& book_name):author("Stanley B.Lippman")
	{
		this->book_name = book_name;
	}
	//same_author的形参是const Book&
	bool same_author(const Book& book)const;
private:
	string book_name;
	string author;
};

bool Book::same_author(const Book& book)const
{
	return (this->author == book.author);
}

int main(void)
{
	//定义了一本书Inside C++ Object Model,其作者是缺省的
	Book a_book("Inside C++ Object Model");

	//定义一个字符串,作为一本书的书名
	string b_book_name("C++ Primer");
	Book b_book(b_book_name);
	if(a_book.same_author(b_book))
	{
		cout<<"The great 2 books are written by great Stanley B.Lippman"<<endl;
	}
	else
	{
		cout<<"Different authors for those 2 books."<<endl;
	}
	return 0;
}




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值