【发布时间】:2018-04-10 14:03:50
【问题描述】:
我想知道一个类型是否定义了带有模板参数的成员函数,但模板参数受 SFINAE 约束。
例如我有一个类型 A 和一个函数 foo
struct A{
template<typename T>
std::enable_if<Condition<T>,ReturnType> foo(T t){ ... }
};
Condition 是一些条件,例如std::is_pos_v
现在我正在使用 boost::hana::is_valid 来确定一个类型是否具有像 foo() 或 foo(int) 这样的成员函数,但是当使用模板参数时我迷路了。
我想写这样的东西
auto has_foo = hana::is_valid([](auto t) -> delctype(hana::traits::declval(t).foo(???)){});
has_foo(hana::type_c<A>); // <-- I want this to return true
问题是我应该放什么而不是????
编译器可能不可能“证明”类型A 满足:“对于满足Condition 的每个类型T,都有一个成员函数A::foo(T)”
所以为了使编译器更容易,我很乐意至少“证明”对于类型 A 成立:“有一个类型 T 这样就有一个成员函数 A::foo(T)”
不幸的是,这在我的示例中仍然很难,因为这需要证明存在满足 Condition 的类型。
因此,出于内省的目的,是否有可能忽略 SFINE?然后我可以选择任意类型并测试例如A::foo(int).
【问题讨论】:
-
这听起来不可能。此外,如果该类型是特定的尚未实例化的类模板怎么办?
-
为什么你想要这个高阶逻辑?您要解决的实际问题是什么?
-
@liliscent 是的,这可能是不可能的。无论如何,我正在使用 C++ 并尝试从类别理论中实现基本概念,例如不同类型的类别、函子、产品、总和、指数对象等。所以代码真的很通用,我想捕捉错误为尽快,否则错误消息将无法阅读。因此,所描述的问题就是我要解决的问题。
-
或者我可以改写一下。我想确保给定的函数对象(struct
A)确实是某个集合的映射(由Condition给出)。 (对我来说,集合是T类型的值的集合,类型满足Condition) -
@JasonRice 我添加了一个我想写的代码。
标签: c++ templates template-meta-programming introspection boost-hana