C++ 对构造函数的模糊调用

C++ Ambigous call to constructor

我有一个 class 有几个构造函数和重载运算符 :

class Utf8String
{
public:

   Utf8String();

   explicit Utf8String( const char * sStr );

   Utf8String( const char * sStrBeg, const char * sStrEnd );

   Utf8String( const char * sStr, uint32_t nCpCount );

   explicit Utf8String( const Utf8String & sStr );

   explicit Utf8String( const Utf8String & sStr, uint32_t nStart = 0, uint32_t nCpCount = UINT32_MAX );

   Utf8String( uint32_t nCpCount, uchar32_t cCodePoint );

   explicit Utf8String( long int iVal );

   explicit Utf8String( double fVal );

   // More stuff

   inline Utf8String operator + ( const char * sStr ) const
   {
      Utf8String sRes( *this ); // ERROR
      return sRes += sStr;
   }

   inline operator const char * () const;

   inline operator char * ();

   inline operator long int () const;

   inline operator double () const;
};

出于某种原因,我遇到了一个错误:

Error   3   error C2668: 'core::Utf8String::Utf8String' : ambiguous call to overloaded function c:\xxx\utf8string.h 280

我尝试在似乎有意义的地方添加明确的关键字。我还向所有构造函数添加了显式,只是为了看看会发生什么,但无论我做什么,我都会收到此错误并且无法弄清楚原因。

你有什么想法吗?谢谢。

这两个函数:

explicit Utf8String( const Utf8String & sStr );

explicit Utf8String( const Utf8String & sStr, uint32_t nStart = 0, uint32_t nCpCount = UINT32_MAX );

不应该同时存在。他们导致了问题。

由于第二个构造函数的其余参数具有 默认 值,如果只传递一个参数,它们将导致模棱两可的错误,如下所示:

 Utf8String s = get_utfString();

 Utf8String s1(s); //which above constructor should be called?

一个修复方法是:删除第二个构造函数的默认值。

此外,这些构造函数是复制构造函数,因此,explicit 没有多大意义。您将使用 explicit 来避免从一种类型 X 到另一种类型 Y 隐式 版本。在这种情况下,避免从 Utf8String const&Utf8String 的隐式转换没有意义,因为这样的转换不会真正导致问题(如果是,那么问题很可能出在其他部分你的代码)。

您的以下两个构造函数都可以作为复制构造函数:

explicit Utf8String( const Utf8String & sStr );
explicit Utf8String( const Utf8String & sStr, uint32_t nStart = 0, uint32_t nCpCount = UINT32_MAX );

他们每个人都匹配 Utf8String( const Utf8String & sStr ) 签名。这是编译器不喜欢的。

你真的应该想想你想使用两个构造函数中的哪一个作为复制构造函数。如果它是第一个,则在第二个构造函数中删除 nStart 的默认值。如果是第二个,则完全放弃第一个构造函数。

事实上,我假设你的第二个构造函数只接受一个子字符串,因此在没有 nStartnCpCount 参数的情况下调用将完全按照复制构造函数的预期工作。所以最简单的方法就是删除这些对中的第一个构造函数。

但是,这可能会导致一些(主要是性能)问题,具体取决于您对 Utf8String 的表示,所以这由您决定。