动态创建 std::vector 并将其传递给另一个函数的各种方法
Various ways of creating std::vector on the fly and passing it to another function
我正在尝试动态创建std::vector
并将其传递给另一个函数的各种方法:
#include <iostream>
#include <vector>
void print(std::vector<int> a)
{
std::cout << a.size() << 'n';
}
int main()
{
print({1, 2, 3, 4, 5});
print(std::vector<int>{1, 2, 3, 4, 5});
print(std::vector<int>({1, 2, 3, 4, 5}));
}
这将产生所需的输出:
$ clang++ -std=c++11 foo.cpp && ./a.out
5
5
5
我想知道这三个调用之间有什么区别:
print({1, 2, 3, 4, 5});
print(std::vector<int>{1, 2, 3, 4, 5});
print(std::vector<int>({1, 2, 3, 4, 5}));
这是另一个例子:
#include <iostream>
#include <vector>
int main()
{
std::vector<int> a = {1, 2, 3, 4, 5};
// std::cout << (a == {1, 2, 3, 4, 5}) << 'n'; // error
std::cout << (a == std::vector<int>{1, 2, 3, 4, 5}) << 'n';
std::cout << (a == std::vector<int>({1, 2, 3, 4, 5})) << 'n';
}
这是输出:
$ clang++ -std=c++11 foo.cpp && ./a.out
1
1
我希望这个问题的答案能成为一个很好的参考 关于此主题的答案,其中答案讨论了以下方面 这些调用:
- 以上三种以及任何其他类似的通过方式
std::vector
到另一个函数。 - 各种方法之间的语义差异。
- 各种方法之间的性能差异(如果有(。
- 最佳实践(如果有(,由于哪种调用是有利的 在另一个。
如果您认为该问题有任何缺点,请随时编辑 问题并改进它。
自 C++17 以来,所有这些都具有完全相同的效果。调用print
函数,并通过调用构造函数vector(std::initializer_list<int>)
来创建函数参数。
第一个可能被认为是更可取的语法,因为它避免了冗余。
在C++17之前,可能会有各种临时对象创建和销毁,但现在这一切都已成为过去。
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- C++-试图将函数指针推回到另一个CPP文件中的矢量时出错
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- 修改函数中的指针(将另一个指针作为参数传递)
- 如何将指针从一个void函数传递到另一个C++
- 如何从另一个文件继承私有成员变量和公共函数
- 使用.find函数在c++中查找字符和另一个字符之间的大小
- C++-我可以创建另一个类的成员并在构造函数中使用它吗
- 如何在C++中将函数发送到另一个进程
- 如何在qt中从另一个类调用函数
- 如何将一个类的函数作为另一个类的另一个函数的参数传递
- 在作为静态成员包含在另一个类中的类的构造函数中使用 cout
- 将 N-arg 函数包装到另一个函数中
- 为什么我的模板化函数需要从一个迭代器转换到另一个迭代器?
- C++重载函数,一个采用基类的参数,另一个采用派生类的参数
- C++从另一个函数退出函数
- 为什么我不能在主函数之外定义一个类的对象(它继承了另一个类)?
- 在一个类中使用另一个类中的函数,而不在 c++ 中使用继承
- C++ STD 函数运算符:有没有一种方法可以通过函数将一个向量映射到另一个向量上?