Czy T musi być kompletnym typem do użycia w `std :: declval <T>`?

Rozważ ten przykład (pochodzący stąd ): #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 =