如何正确地从函数 (type_traits) 给出向量
How correctly give vector from function (type_traits)
如何从此operator+()
返回std::vector
?
#include <iostream>
#include <vector>
#include <type_traits>
#include <algorithm>
#include <utility>
template<typename> struct is_std_vector : std::false_type {};
template<typename T, typename A> struct is_std_vector<std::vector<T, A>> : std::true_type {};
template <typename T>
std::enable_if_t<is_std_vector<std::decay_t<T>>::value>
operator+(T&& vec1, T&& vec2)
{
for (int i = 0; i < vec2.size(); ++i)
vec1.emplace_back(std::forward<int>(vec2.at(i)));
return vec1;
}
int main()
{
std::vector<int> vec1{ 1,2,3,4,5 };
std::vector<int> vec2{ 2,3,4,5,6 };
std::vector<int> vecResult;
vecResult = std::move(vec1) + std::move(vec2);
for (const auto& itr : vecResult)
std::cout << itr << std::endl;
return 0;
}
现在函数返回 void,但我不知道为什么,我想给std::vector
作为对operator+(T&& vec1, T&& vec2)
的前向引用并返回std::vector
。我认为这很好,但编译器知道得更好。一些建议?
错误编译器
C2679 二进制 '=':未找到采用右操作数的运算符 类型为"无效"(或没有可接受的转换(
问题是std::enable_if_t
的默认类型是 ,当条件为 true 时,是void
。
所以,而不是返回void
std::enable_if_t<is_std_vector<std::decay_t<T>>::value>
operator+(T&& vec1, T&& vec2)
我想你应该返回T
或类似的东西
std::enable_if_t<is_std_vector<std::decay_t<T>>::value, T>
operator+(T&& vec1, T&& vec2)
相关文章:
- 写入向量<向量<bool>>
- 函数向量_指针有不同的原型,我可以构建一个吗
- std::向量与传递值的动态数组
- 将值指定给向量(2D)的向量中的某个位置
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 如何使用向量的template_back函数
- 尝试通过多个向量访问变量时,向量下标超出范围
- 如何通过派生类函数更改基类中的向量
- C++从另一个类访问公共静态向量的正确方法是什么
- 如何将ampl中的集合表示为c++中的向量
- 变量没有改变?通过向量的函数调用
- 迭代时从向量和内存中删除对象
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 如何为模板化对象创建模板向量?VS正在投掷C3203
- 计算排序向量的向量中唯一值的计数
- 矩阵向量乘法(cublasDgemv)返回零
- 一对向量构造函数:初始值设定项列表与显式构造
- 将结构向量排序为子组
- 在C++中调整向量中的索引
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么