std::transform with std::reference_wrapper
std::transform with std::reference_wrapper
如何与容纳std::reference_wrapper
类型对象的容器结合使用std::transform
?从const std::vector<std::reference_wrapper<const float>>
阅读并写入std::vector<float>
时,一切都起作用,但是如果我尝试写入std::vector<std::reference_wrapper<float>>
,则不会编译错误
/usr/include/c /5/bits/stl_algo.h:4214:错误:使用删除函数>'std :: reference_wrapper&lt; _tp> :: reference_wrapper(_tp&amp&amp;&amp;&amp;&amp;(' __结果= __binary_op( __ first1, *__ first2(;
我认为它正在尝试替换参考,而不是更改引用值的值。有没有一种方法可以使用转换来实现这一目标,或者我希望写自己的功能?
编辑:添加了一个示例供参考:
#include <iostream>
#include <vector>
#include <functional>
#include <algorithm>
int main()
{
std::vector<float> v(3, 1.0f);
std::vector<std::reference_wrapper<float>> refVector;
refVector.reserve(v.size());
for(auto& elem : v)
{
refVector.push_back((std::reference_wrapper<float>)elem);
}
std::vector<float> v2(3, 2.0f);
std::vector<float> v3(3, 3.0f);
std::vector<float> v4(3);
for(auto& elem : v)
std::cout << elem << std::endl; // all 1s
std::transform(refVector.begin(), refVector.end(), v3.begin(), v4.begin(), std::plus<float>());
for(auto& elem : v4)
std::cout << elem << std::endl; // all 4s
std::transform(v2.begin(), v2.end(), v3.begin(), refVector.begin(), std::minus<float>()); // doesn't compile
for(auto& elem : v)
std::cout << elem << std::endl; // want all -1s
return 0;
}
如果您试图覆盖std::vector<std::reference_wrapper<float>>
中引用的现有float
s,则需要将std::reference_wrapper<float>
解散到float &
中的东西。boost::indirect_iterator
是这样的事情,尽管如果您无法添加助推器依赖,可以很容易地编写自己的迭代器适配器。
一个示例用法:
std::vector<float> src1 = /* values */, src2 = /* other values */;
std::vector<std::reference_wrapper<float>> dest = /* references to somewhere */;
boost::indirect_iterator<std::reference_wrapper<float>, float> indirected(dest.begin());
std::transform(src1.begin(), src1.end(), src2.begin(), indirected, std::plus<float>());
草图实现
struct indirect_iterator
{
/* a bunch of typedefs go here */
indirect_iterator& operator++() { ++inner; }
float & operator*() { return inner->get(); }
float * operator->() { return &inner->get(); }
private:
std::vector<std::reference_wrapper<float>>::iterator inner;
}
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- 使用一个考虑到std::map中键值的滚动或换行的键
- 如何从 std::atomic 中提取指针 T<T>?
- 为什么 std::unique 不调用 std::sort?
- 传递对variadic-templates的引用使用std ::参考 - wrapper
- C++98 Wrapper for std::map::at()