Consideriamo seguente esempio:ambiguità tra la funzione const migliore corrispondenza e l'altra funzione
#include <type_traits>
#if 1
struct X {};
struct O
{
O(X) { ; }
};
#else
struct O {};
struct X
{
operator O() { return {}; }
};
#endif
static_assert(std::is_convertible< X, O >::value);
struct S
{
void f(X) const { ; }
void f(O) { ; }
};
#include <cstdlib>
int
main()
{
S s;
s.f(X{});
return EXIT_SUCCESS;
}
dà un errore:
error: call to member function 'f' is ambiguous
Quando ho rimuovere const
-qualifier, poi l'errore cessa di esistere. Ugualmente lo stesso accade, se aggiungo const
-qualificatore al secondo sovraccarico di f
. Cioè se entrambi i sovraccarichi sono ugualmente const
-qualificati, allora tutto è OK.
Perché è così?
Il mio compilatore è clang 3.8.
'std :: declval
() .f (O (x))' vs 'std :: declval() .f (x)' (per 'std :: declval () .f (x) '). conversione definita dall'utente rispetto alla promozione const. – Jarod42@ Jarod42 vuol dire che durante la risoluzione la forza di entrambe le alternative è la stessa? – Orient
@Orient Questa è la definizione di ambiguità. – erip