构造函数采用引用参数的显式修饰符
Explicit modifier for constructors taking reference argument
我读到过定义单参数构造函数 explicit
以避免隐式转换是一种很好的做法。我理解将 int 值提升为 class 对象的陷阱。我想知道它是否也适用于接受引用类型的构造函数。在这种情况下如何引发隐式转换:
class Foo
{
public:
Foo(Bar& bar) { }
};
如果构造函数接受指针,情况是否会发生变化,是否可以从 NULL
和 nullptr
转换?
class Foo
{
public:
Foo(Bar* bar) { }
};
两者都是。带有签名的函数
void acceptFoo(const Foo& foo)
如果您在那里传递 Bar
,将使编译器创建一个 Foo
。
0
和 nullptr
相同。
我读到过定义单参数构造函数 explicit
以避免隐式转换是一种很好的做法。我理解将 int 值提升为 class 对象的陷阱。我想知道它是否也适用于接受引用类型的构造函数。在这种情况下如何引发隐式转换:
class Foo
{
public:
Foo(Bar& bar) { }
};
如果构造函数接受指针,情况是否会发生变化,是否可以从 NULL
和 nullptr
转换?
class Foo
{
public:
Foo(Bar* bar) { }
};
两者都是。带有签名的函数
void acceptFoo(const Foo& foo)
如果您在那里传递 Bar
,将使编译器创建一个 Foo
。
0
和 nullptr
相同。