2

这是我失败的尝试:

#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){})
    };
}
4

1 回答 1

0

在你说的评论中,

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

在这种情况下,您可以使用本地结构并在其中定义一个静态函数。像这样的东西(如果它对你有帮助的话)

#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。您可以在本地定义静态成员函数,并将其传递给其他函数。

于 2012-07-16T19:34:46.730 回答