2
Должен ли T быть полным типом для использования в `std :: declval <T>`?
Рассмотрим этот пример ( отсюда ): #include <type_traits> #include <iostream> template <typename U> struct A { }; struct B { template <typename F = int> A<F> f() { return A<F>{}; } using default_return_type = decltype(std::declval<B>().f()); }; int main() { B::default_return_type x{}; std::cout << std::is_same< B::default_return_type, A<int>>::value; } Он компилируется без …