构造函数采用引用参数的显式修饰符

Explicit modifier for constructors taking reference argument

我读到过定义单参数构造函数 explicit 以避免隐式转换是一种很好的做法。我理解将 int 值提升为 class 对象的陷阱。我想知道它是否也适用于接受引用类型的构造函数。在这种情况下如何引发隐式转换:

class Foo
{
public:
    Foo(Bar& bar) { }
};

如果构造函数接受指针,情况是否会发生变化,是否可以从 NULLnullptr 转换?

class Foo
{
public:
    Foo(Bar* bar) { }
};

两者都是。带有签名的函数

void acceptFoo(const Foo& foo)

如果您在那里传递 Bar,将使编译器创建一个 Foo

0nullptr 相同。