簡體   English   中英

std :: transform with std :: reference_wrapper

[英]std::transform with std::reference_wrapper

如何將std::transform與包含std::reference_wrapper類型對象的容器結合使用? 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 <_Tp> :: reference_wrapper(_Tp &&)[with _Tp = float]' __result = __binary_op( __first1 ,* __ first2);

我認為它正在嘗試替換參考,而不是更改參考值的值。 有沒有一種方法可以使用transform實現此目的,還是我應該編寫自己的函數?

編輯:添加了示例供參考:

#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 ,則需要將std::reference_wrapper<float>float & boost::indirect_iterator就是這樣,盡管如果您不能添加boost依賴關系,則編寫自己的迭代器適配器很容易。

用法示例:

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;
} 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM