gpt4 book ai didi

c++ - 推断 lambda 的类型衰减为函数指针

转载 作者:行者123 更新时间:2023-11-28 04:26:48 27 4
gpt4 key购买 nike

所以我制作了这个模板来定义内联仿函数:

template <typename F, F* f>
struct AsFunctor
{
template <typename... Args>
std::invoke_result_t<F, Args...> operator()(Args&&... args) { return f(std::forward<Args>(args)...); }
};

可以这样使用:

std::unique_ptr<char, AsFunctor<void(char*), +[](char* c) {/*STUFF*/}>> p;

除了我必须不必要地声明我的函数类型两次外,效果很好。有什么办法可以让编译器推断出来吗?我已经以各种方式尝试过 decltype,例如

#define AS_FUNCTOR(lambda) AsFunctor<decltype(+lambda), +lambda>

但它们都是编译错误,因为 lambda 不能出现在未计算的上下文中。

最佳答案

您可以对仿函数使用auto,然后使用decltype 推导类型。

template <auto F>
struct AsFunctor {
template <typename... Args>
std::invoke_result_t<decltype(F), Args...> operator()(Args&&... args) {
return F(std::forward<Args>(args)...);
}
};

int main() {
int i;
std::unique_ptr<char, AsFunctor<+[](char* c) { /*STUFF*/ }>> p;
}

我不知道上下文,但通常你不需要任何自定义仿函数类型(最好立即使用模板,查看来自 STL 的任何示例)或 std::function.

关于c++ - 推断 lambda 的类型衰减为函数指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54104716/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com