Với mã sau đây, tại sao trình biên dịch không giải quyết được chuyển đổi ngầm khi xây dựng Bar
? Tức là, hãy xây dựng Foo
giống như a
được xây dựng, cái nào (nên) sau đó được sử dụng để xây dựng Bar
?Chuyển đổi ngầm định trong C++
#include <string>
class ImplicitlyConvertToChar
{
public:
ImplicitlyConvertToChar(const char* a_char)
: m_string(a_char)
{ }
ImplicitlyConvertToChar(const char* a_char, size_t a_end)
: m_string(a_char)
{
}
template <typename T_String>
ImplicitlyConvertToChar(T_String const& a_string)
: m_string(a_string.begin())
{
}
operator char const *() const
{ return m_string; }
const char* m_string;
};
class Foo
{
public:
Foo(const ImplicitlyConvertToChar& a_charLike)
: m_string(a_charLike)
{ }
const char* m_string;
};
class Bar
{
public:
Bar(const Foo& a_foo)
: m_foo(a_foo)
{ }
Foo m_foo;
};
int main()
{
Foo a("this works");
Bar b("Why doesn't this?");
}
Đó là một phần của chuyển đổi tiêu chuẩn, tiềm ẩn không thể bị xâu chuỗi như vậy. Bạn chỉ có thể có một chuyển đổi tiềm ẩn. – IronMensan