Kann jemand versuchen, das zu erklären?Seltsames conetexpr Verhalten für innere Klasse
template<typename T, size_t S = T::noElems()>
struct C
{
};
struct X
{
enum E { A, B, C };
static constexpr size_t noElems() { return C+1; };
};
struct K
{
C<X> cx; // this DOES compile
};
struct Y
{
struct Z
{
enum E { A, B, C };
static constexpr size_t noElems() { return C+1; };
};
C<Z, Z::C+1> cyz; // this DOES compile
C<Z> cyz; // <--- this does NOT compile
};
Clang beschwert 'undefined Funktion‚noElems‘kann nicht in einem konstanten expression' verwendet werden –
ich denke, es könnte beantwortet werden [hier] (http://stackoverflow.com/a/8108406/4035785) –
Können Sie die Zusammenstellung hinzufügen Fehler in deine Frage? – Angew