我遇到了这样一种情况,我有一对类,我将它们称为Legacy和Modern,它们具有来自相同类型的转换构造函数。
struct Legacy { Legacy(int); };
struct Modern { Modern(int); };甚至可能是模板化的构造函数:
struct Legacy { template <typename T> Legacy(T); };
struct Modern { template <typename T> Modern(T); };类似地,这些类型上有许多重载的函数:
void f(Legacy) { ... }
void f(Modern) { ... }有没有办法修改Legacy和Modern的构造函数,使Modern的构造函数始终是隐式转换的首选?
f(42); // should call f(Modern(42))over.ics.user似乎不允许在涉及用户定义的转换的隐式转换中进行任何排名(换句话说,调用是不明确的,仅此而已),但我可能忽略了一些东西。
发布于 2020-01-16 02:15:47
最简单的方法是显式地使用Legacy的构造函数,这应该和排名有相同的效果,因为即使你有“排名”的隐式构造函数,调用Legacy的唯一方法也是显式调用它。
也就是说,转换构造函数可能是混淆和错误的来源,所以您可以考虑将它们都显式地表示出来。
https://stackoverflow.com/questions/59756911
复制相似问题