template <typename>
struct Functor;
template <typename Return, typename... Args>
struct Functor<Return(Args...)> {
private:
struct BaseWrapper {
Return (*call)(BaseWrapper* wrapper, Args... args) = nullptr;
};
template <typename Invocable>
struct Wrapper : BaseWrapper {
std::decay_t<Invocable> inv;
static PLY_NO_INLINE Return call(BaseWrapper* wrapper, Args... args) {
return static_cast<Wrapper*>(wrapper)->inv(std::forward<Args>(args)...);
}
template <typename I>
PLY_INLINE Wrapper(I&& inv) : BaseWrapper{&call}, inv{std::forward<I>(inv)} {
}
};
BaseWrapper* wrapper = nullptr;
public:
PLY_INLINE Functor() = default;
PLY_INLINE Functor(Functor&& other) : wrapper{other.wrapper} {
other.wrapper = nullptr;
}
PLY_INLINE bool isValid() const {
return this->wrap
plywood的functor类
最新推荐文章于 2024-09-08 09:58:56 发布
Plywood的Functor类通过模板和SFINAE技术实现对类函数对象的适配。构造函数的关键在于检测给定类型I是否支持特定的调用方式。利用`std::declval`创建临时对象并检查调用表达式的可行性,如果成功,则能成功构建Functor实例。测试展示了不同类型的函数对象如何被正确地模板展开和适配。
摘要由CSDN通过智能技术生成