Warum funktioniert SFINAE (enable_if) nicht für Elementfunktionen einer Klassenvorlage?

#include <type_traits>

struct A{};
struct B{};

template <typename T>
struct Foo
{
    typename std::enable_if<std::is_same<T, A>::value>::type
    bar()
    {}

    typename std::enable_if<std::is_same<T, B>::value>::type
    bar()
    {}
};

Fehlermeldung

14:5: error: 'typename std::enable_if<std::is_same<T, B>::value>::type Foo<T>::bar()' cannot be overloaded 10:5: 
error: with 'typename std::enable_if<std::is_same<T, A>::value>::type Foo<T>::bar()'

Quelle auf cpp.sh. Ich dachte beidetypename std::enable_if<std::is_same<T,?>::value>::type konnte nicht gleichzeitig gültig sein.

Bearbeite

Für die Nachwelt hier ist meine Bearbeitung auf der Grundlage von @ KerrekSB Antwort -SFINAE funktioniert nur für abgeleitete Vorlagenargumente

#include <type_traits>

struct A{};
struct B{};

template<typename T>
struct Foo
{
    template<typename U = T>
    typename std::enable_if<std::is_same<U,A>::value>::type
    bar()
    {
    }

    template<typename U = T>
    typename std::enable_if<std::is_same<U,B>::value>::type
    bar()
    {
    }
};

int main()
{
};

Antworten auf die Frage(2)

Ihre Antwort auf die Frage