//--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实际上增加了参数。
时间: 2024-10-11 18:05:00