C++11 lambda 表达式作用在传统C回调函数上

2019-06-20  本文已影响0人  脱水沙丁鱼

作者:赵小刚
原文:C++11 lambda 表达式作用在传统C回调函数上

//--std=c++11
#include <functional>
#include <cstdio>

typedef bool (*IS_X_NUM)(int);

void show_x_num(int * array, int len, IS_X_NUM is_x_num)
{
    for(int i = 0; i < len; i++) {
        if(is_x_num(array[i])) {
            printf("%d ", array[i]);
        }
    }
    printf("\n");
}

void show_x_num2(int * array, int len, std::function<bool(int)> is_x_num)
{
    for(int i = 0; i < len; i++) {
        if(is_x_num(array[i])) {
            printf("%d ", array[i]);
        }
    }
    printf("\n");
}

int main() {
    int list[] = { 2, 3, 5, 8, 19, 20, 21 };

    printf("show all:\t");
    show_x_num(list, 7, [](int){return true;});

    printf("show even num:\t");
    show_x_num(list, 7, [](int a){return !(a % 2);});

    int two = 2;
    printf("show even num:\t");

    //show_x_num(list, 7, [=](int a){return !(a % two);});
    //error: cannot convert ‘main()::__lambda2’ to ‘IS_X_NUM {aka bool (*)(int)}’ for argument ‘3’ to ‘void show_x_num(int*, int, IS_X_NUM)’

    show_x_num2(list, 7, [=](int a){return !(a % two);});

    return 0;
}

上面的例子中,show_x_num 的第3个参数是一个传统的函数指针,我们可以使用不带捕获([captrue])的lambda表达式作为show_x_num的第3个参数(第31行和第34行),但使用带捕获的lambda就会编译出错(第39行).

如果要使用带捕获的lambda,需把函数参数声明成 std::function<> (第17行), 第42行使用带捕获的lambda就成功了.

之所以会这样(带捕获的lambda表达式无法转化为传统函数指针),我理解带捕获的lambda实际上增加了参数。

上一篇下一篇

猜你喜欢

热点阅读