【问题标题】:How can I degrade a lambda to a function pointer in VS2010?如何在 VS2010 中将 lambda 降级为函数指针?
【发布时间】:2012-07-15 16:45:42
【问题描述】:

这是我失败的尝试:

#define decltype(...) std::identity<decltype(__VA_ARGS__)>::type

template<typename T>
auto* degrade(const T& f) -> decltype(&T::operator())
{
    return &T::operator();
} 

int main()
{
    std::array<void(int), 1> stuff =
    {
        degrade([](int){})
    };
}

【问题讨论】:

  • 你想达到什么目的?你为什么不改用std::function
  • @Nawaz 主要是为了这样做。顺便说一句,我已经尝试了上述的 50 种排列,确切的一种并不完全有意义,但你明白了。 decltype 宏用于启用使用 decltype 的范围解析(VS2010 不支持)
  • 但是为什么要把lambda变成函数指针呢?为什么首先会出现这种需求?
  • @ephemient 没有捕获的 Lambda 可以转换为函数指针。 VS2010 不支持。 - 我正在使用的库 Nawaz 有一个采用函数指针的方法,使用 lambda 会稍微干净一些(这不是什么大问题,但我想看看在 VS2010 中是否可能)
  • @Dave 不是这个。它需要魔法,因为 lambda 本身就是不透明的魔法类型。

标签: c++ visual-studio-2010 visual-c++ c++11


【解决方案1】:

在你说的评论中,

VS2010 不支持。 - 我正在使用的库 Nawaz 有一个采用函数指针的方法,使用 lambda 会稍微干净一些(这不是什么大问题,但我想看看在 VS2010 中是否可行)

在这种情况下,您可以使用本地结构并在其中定义一个静态函数。 Something like this (well if it helps you):

#include <iostream>

void call(void (*f)(int))
{
    for(int i = 0 ; i < 10 ; i++)
         f(10 * i);
}

int main() 
{
    struct local
    {
        static void print(int i) { std::cout << i << std::endl; }
    };
    call(&local::print);
}

它很方便 - 或多或少像 C++11 lambda。您可以本地定义一个静态成员函数,并将其传递给其他函数。

【讨论】:

    猜你喜欢
    • 2016-02-06
    • 2021-10-05
    • 2019-09-19
    • 2018-06-15
    • 2018-10-29
    • 1970-01-01
    • 2015-11-25
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多