我有这样的功能: template typename A, typename Bvoid foo(const B b){ ...} A应该是可选的;如果没有在函数调用中明确定义,则应将其设置为B.目的是避免不必要的详细代码: int i;// First variant: A is
template <typename A, typename B> void foo(const B & b) { ... }
A应该是可选的;如果没有在函数调用中明确定义,则应将其设置为B.目的是避免不必要的详细代码:
int i; // First variant: A is specified explicitly foo<float>(i); // Second variant: A is set to B implicitly // This is because foo < int > (i) is unnecessarily verbose foo(i);
但是,我还没有办法做到这一点.任何人都能想出一个吗?
#include <type_traits> struct deduce_tag; template <typename PreA = deduce_tag, typename B> void foo(const B & b) { using A = std::conditional_t< std::is_same<PreA, deduce_tag>::value, B, PreA >; }