我目前正在学习lambda函数如何工作,因此尝试将数组传递给Lambda函数,我想在其中打印出来。我的问题是,我不明白,如何将数组传递给函数。这个问题似乎源于数组传递给lambda函数时的转换。这是函数的当前状态:
auto print_array = [](int &array, int i) -> int {
//print out array
return 0;
}(&actual_array, actual_i);
非常感谢帮助!
您不能按值传递数组,并且传递指针的语法都是错误的。
实际上很容易将指针或引用传递给数组。使用泛型lambdas,您可以忽略维度是类型的一部分这一事实,只需简单地写:
#include <iostream>
int main()
{
int actual_array[5] = {7,8,9,2,1};
const int actual_i = 3;
auto print_array = [](auto& ar, int i) {
std::cout << ar[i] << '\n';
};
print_array(actual_array, actual_i);
}
在这个例子中,你调用的print_array
实例化接受隐藏在int(&)[5]
后面的auto&
。
如果由于某种原因你不能遵守通用lambda(基本上是模板),那就去老派:
#include <iostream>
int main()
{
int actual_array[5] = {7,8,9,2,1};
const int actual_i = 3;
auto print_array = [](const int* ar, int i) {
std::cout << ar[i] << '\n';
};
print_array(&actual_array[0], actual_i);
}
这些都不是lambda所特有的。任何功能都是一样的。
声明一个lambda变量,它接受一个数组(和长度)作为参数;
using namespace std;
auto print_array = [](const int *items, int length) {
for (int i = 0; i < length; i++)
{
cout << items[i] << endl;
}
};
要调用:
int myArray[] = { 11,22,33,44 };
print_array(myArray, 4);
数组不能是函数参数。
此外,int
引用不能绑定到int
数组。也不能将整数引用用作数组。
但是,可以使用下标运算符访问指针,其方式与数组的方式非常相似。数组的名称实际上隐式转换为指向第一个元素的指针。此转换称为衰减:
int array[n];
int* ptr_to_first_element = array;
assert(ptr_to_first_element[i] == array[i]);
因此,您可以使用整数指针作为函数参数,并将指针传递给数组的第一个元素:
void foo(int *array, std::size_t size);
// ...
int array[n];
foo(array, n);
以上所有内容也适用于lambdas。所以你可以写:
auto print_array = [](int *array, int i) -> int {
// ^ notice this
//print out array using the pointer
return 0;
}(&actual_array, actual_i);
但是,您可以将一个引用数组的特定大小作为函数的参数:
void foo(int (&array)[20]);
这有点限制,因为引用只能绑定到一个特定大小的数组。模板可以很容易地为任何大小的数组生成这样的函数:
template<std::size_t size>
void foo(int (&array)[size]);
多态lambda(在C ++ 14中引入)极大地简化了这一点:
int actual_array[10];
auto print_array = [](auto &array, int i) -> int {
// ^^^^^^ notice this
//print out the referred array
return 0;
}(&actual_array, actual_i);
在这种情况下,array
论证的类型将被推断为int (&)[10]
。
附: “打印出来”数组听起来像是不需要修改数组的东西。考虑这一点,如果可能的话,使用const
指针指向第一个元素或const
引用作为参数。
请注意,std::array
包装器是一个类,而不是一个数组。因此,std::wrapper
不会隐式衰减到指针,如果需要,std::array
可以用作函数参数。