如何将C函数的第一个参数设为第二个参数的默认值?
- 内容介绍
- 文章标签
- 相关推荐
本文共计250个文字,预计阅读时间需要1分钟。
我有这样的功能:template void foo(const B& b) {...} A 应该是可选的;如果没有在函数调用中明确定义,则应将其设置为 B 的目标类型。例如,是避免不必要的详细代码:int i; // 第一种情况:A 是 B 的子类型
我有这样的功能: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 >; }
本文共计250个文字,预计阅读时间需要1分钟。
我有这样的功能:template void foo(const B& b) {...} A 应该是可选的;如果没有在函数调用中明确定义,则应将其设置为 B 的目标类型。例如,是避免不必要的详细代码:int i; // 第一种情况:A 是 B 的子类型
我有这样的功能: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 >; }

