问题描述
我使用了 vector::emplace_back
以避免在填充向量时构造时间对象.这里有一个简化版本:
I have used vector::emplace_back
in order to avoid constructing temporal objects while filling a vector. Here you have a simplified version:
但我想用 std::fill_n
代替:
不过,通过这种方式,将创建临时副本.在这种情况下,我不知道如何使用 emplace
.我想我需要像 std::back_emplacer
这样的东西,但我找不到这样的东西.那是 C++11 的一部分,但还没有在 GCC 中实现吗?如果它不是 C++11 的一部分,还有其他方法可以做到吗?
In this way, temporal copies will be created, though. I do not know how to use emplace
in this situation. I guess I would need something like std::back_emplacer
, but I could not find such a thing. Is that part of C++11, but not implemented in GCC yet? If it is not part of C++11, is there any other way to do that?
推荐答案
通常使用元组来简化传递可变数量的项目(在这种情况下,要转发到 emplace_back
的参数),使用一个小技巧来解包元组回来.因此,通过要求用户使用元组工厂函数(std::make_tuple
、std::tie
, std::forward_as_tuple
) 在它有意义的地方:
It's common to use tuples to ease the pass a variadic number of items (in this case, parameters to forward to emplace_back
), with a little technique to unpack the tuple back. As such it is possible to write a back_emplacer
utility by requiring the user to make use of the tuple factory functions (one of std::make_tuple
, std::tie
, std::forward_as_tuple
) where it make sense:
代码演示可用.在你的情况下,你想调用 std::fill_n(back_emplacer(v), 10, std::forward_as_tuple(1, 1.0));
(std::make_tuple
也可以接受).您还需要常用的迭代器来使功能完整——我为此推荐 Boost.Iterators.
A demonstration of the code is available. In your case you'd want to call std::fill_n(back_emplacer(v), 10, std::forward_as_tuple(1, 1.0));
(std::make_tuple
is also acceptable). You'd also want the usual iterator stuff to make the feature complete -- I recommend Boost.Iterators for that.
但是我必须强调的是,当与 std::fill_n
一起使用时,这样的实用程序并没有带来太多好处.在您的情况下,它将保存临时 Foo
的构造,以支持引用元组(如果您要使用 std::make_tuple
,则为值元组).我把它留给读者去寻找其他一些 back_emplacer
有用的算法.
I must really stress however that such a utility doesn't bring much when used with std::fill_n
. In your case it would save the construction of the temporary Foo
, in favour of a tuple of references (a tuple of values if you were to use std::make_tuple
). I leave it to the reader to find some other algorithm where back_emplacer
would be useful.
这篇关于将 emplace 与 std::fill 等算法一起使用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!