在下面的代碼中,使用參數{1,2}對實例b的成員函數F進行編譯並調用B::F(std::initializer_list<int>)
。但是,如果我從支撐-初始化列表中刪除一個元素,並使用剛剛{1},我得到一個錯誤爲什麼帶有一個元素的braced-init-list類型切換到元素本身的類型?
9 : error: no matching function for call to 'begin(int)' using type = decltype(std::begin(std::declval<T>()));
我不明白爲什麼編譯器正在尋找begin(int)
,而不是begin(initializer_list<int>)
我一直在玩這個https://godbolt.org/g/tMyYQs,我在clang和g ++上都得到了同樣的錯誤。我錯過了什麼?
#include <type_traits>
#include <iterator>
template< bool B, class T = void >
using enable_if_t = typename std::enable_if<B,T>::type;
template <typename T>
struct mytrait {
using type = decltype(std::begin(std::declval<T>()));
};
template <typename T>
class A {
public:
template <typename TA, typename =
enable_if_t<std::is_same<T, typename mytrait<TA>::type>::value>>
A(TA &&){}
};
class B
{
public:
void F(A<int>);
void F(std::initializer_list<int>);
};
int main()
{
B b;
b.F({1,2}); // compiles fine
#if 0
b.F({1}); // causes mytrait<int>::type to be examined,
// not mytrait<std::initializer_list<int>>::type
#endif
}
由於「統一初始化」:-) –