这是组合std::generate_n和std::back_inserter的正确方法吗
Is this correct way to combine std::generate_n and std::back_inserter?
为了尽可能多地使用STL,我想知道是否可以将std::generate和std::back_inserter结合使用,这样我就可以做与以下代码相同的事情:
static const size_t nitems=1024*1024;
std::string mrbig;
for (size_t pos=0; pos<nitems; ++pos)
mrbig.push_back('a'+ (rand()%26));
我试过
std::generate_n(std::back_inserter(mrbig),nitems,[](){return 'a'+(rand()%26);});
它似乎还可以,但我想确定我没有搞砸什么。
generate_n
要求其第一个参数满足OutputIterator
,而back_insert_iterator
则满足(其iterator_category
为output_iterator_tag
)。
代码的潜在问题:
std::generate_n(std::back_inserter(mrbig),nitems,[](){return 'a'+(rand()%26);});
- 调用
mrbig.reserve(nitems)
会更有效率 - 您应该使用
<random>
中的c++03std::rand
或c++11uniform_int_distribution<>
,而不是crand
- lambda捕获和lambda主体之间的括号
()
对于不带参数的lambda来说是不必要的,尽管有些人更喜欢它们 - 不能保证在实现字符集中字母
a-z
形成连续块;例如,在EBCDIC中,i
和j
不相邻。我相信唯一可移植的形式是在程序中存储一个字符串"abcd...xyz"
并对其进行索引:我如何在C中编写一个从a到z和从a到z的for循环
相关文章:
- 使用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中键值的滚动或换行的键
- 使用back_inserter()或inserter()提高std::copy()的效率
- 为什么std::inserter这么慢
- 我可以一直使用std::inserter(container,container.end())而不是std::back_
- 对std::inserter对std::set使用.begin()和.end()有区别吗?