处理const向量时,以下内容不起作用:
const std::vector<std::string> v;
v.push_back("test"); // error: v cannot be modified
相反,您必须在构造它的同一行初始化向量。但是,即使有这个限制,boost::make_transform_iterator
也可以在将它们推入v之前轻松地对另一个向量元素执行某些操作。在此示例中,convert
是一个一元函数,它返回一个转换后的输入元素版本:
auto beg = boost::make_transform_iterator(args.begin(), convert);
auto end = boost::make_transform_iterator(args.end(), convert);
const std::vector<const char*> vc { beg, end };
我已经看过<iterator>
中可用的功能,但没有看到相同的功能。它只是缺失或标准库没有它的原因吗?
答案 0 :(得分:6)
对于C ++ 11,总有 lambda inplace初步技巧:
const auto vc = [&]{
std::vector<const char*> tmp(v.size());
std::transform(v.begin(), v.end(), tmp.begin(), convert);
return tmp;
}();
或
const auto vc = [&]{
std::vector<const char*> tmp;
tmp.reserve(v.size());
std::transform(v.begin(), v.end(), back_inserter(tmp), convert);
return tmp;
}();
据说,我更喜欢Boost Range适配器:(也 Live On Coliru )
const auto vc = boost::copy_range<std::vector<const char*> >(v | transformed(convert));
#include <algorithm>
#include <vector>
#include <iterator>
#include <string>
#include <functional>
#include <iostream>
int main()
{
const std::vector</* const */ std::string> v { "test", "goodbye" };
auto convert = std::mem_fn(&std::string::c_str);
const auto vc = [&]{
std::vector<const char*> tmp;
tmp.reserve(v.size());
std::transform(v.begin(), v.end(), back_inserter(tmp), convert);
return tmp;
}();
for (auto cc : vc)
std::cout << cc << "\n";
}