<tfoot id='ijZBo'></tfoot><legend id='ijZBo'><style id='ijZBo'><dir id='ijZBo'><q id='ijZBo'></q></dir></style></legend>

    <small id='ijZBo'></small><noframes id='ijZBo'>

        <i id='ijZBo'><tr id='ijZBo'><dt id='ijZBo'><q id='ijZBo'><span id='ijZBo'><b id='ijZBo'><form id='ijZBo'><ins id='ijZBo'></ins><ul id='ijZBo'></ul><sub id='ijZBo'></sub></form><legend id='ijZBo'></legend><bdo id='ijZBo'><pre id='ijZBo'><center id='ijZBo'></center></pre></bdo></b><th id='ijZBo'></th></span></q></dt></tr></i><div id='ijZBo'><tfoot id='ijZBo'></tfoot><dl id='ijZBo'><fieldset id='ijZBo'></fieldset></dl></div>
          <bdo id='ijZBo'></bdo><ul id='ijZBo'></ul>
      1. 从 C++11 中的函数调用返回 std::vector 的正确方法(移动语义)

        Proper way (move semantics) to return a std::vector from function calling in C++11(从 C++11 中的函数调用返回 std::vector 的正确方法(移动语义))
        <legend id='otuxQ'><style id='otuxQ'><dir id='otuxQ'><q id='otuxQ'></q></dir></style></legend>
          <bdo id='otuxQ'></bdo><ul id='otuxQ'></ul>

          <i id='otuxQ'><tr id='otuxQ'><dt id='otuxQ'><q id='otuxQ'><span id='otuxQ'><b id='otuxQ'><form id='otuxQ'><ins id='otuxQ'></ins><ul id='otuxQ'></ul><sub id='otuxQ'></sub></form><legend id='otuxQ'></legend><bdo id='otuxQ'><pre id='otuxQ'><center id='otuxQ'></center></pre></bdo></b><th id='otuxQ'></th></span></q></dt></tr></i><div id='otuxQ'><tfoot id='otuxQ'></tfoot><dl id='otuxQ'><fieldset id='otuxQ'></fieldset></dl></div>

            <tbody id='otuxQ'></tbody>

              <small id='otuxQ'></small><noframes id='otuxQ'>

                • <tfoot id='otuxQ'></tfoot>
                  本文介绍了从 C++11 中的函数调用返回 std::vector 的正确方法(移动语义)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我想填充 std::vector(或其他一些 STL 容器):

                  I want to fill std::vector (or some other STL container):

                  class Foo {
                  public:
                    Foo(int _n, const Bar &_m);
                  private:
                    std::vector<Foo> fooes_;
                  }
                  

                  1.好看的演员,昂贵的性能

                  std::vector<Foo> get_vector(int _n, const Bar &_m) {
                    std::vector<Foo> ret;
                    ... // filling ret depending from arguments
                    return ret;
                  }
                  
                  Foo::Foo(int _n, const Bar &_m) : fooes_(get_vector(_n, _m) {}
                  

                  2.更好的性能,更糟糕的 ctor

                  void fill_vector(int _n, const Bar &_m, std::vector<Foo> &_ret) {
                    ... // filling ret depending from arguments
                  }
                  
                  Foo::Foo(int _n, const Bar &_m) { fill_vector(_n, _m, fooes_); }
                  

                  是否可以使用 C++0x(移动语义功能等)重写第一个示例中的 get_vector 函数以避免冗余复制和构造函数调用?

                  Is it possible to rewrite get_vector function from 1st example with C++0x (move semantics features and so on) to avoid redundant copying and constructor calls?

                  推荐答案

                  如果您使用的是与 C++0x 兼容的编译器和标准库,您可以从第一个示例中获得更好的性能什么都不做.get_vector(_n, _m) 的返回值是一个临时值,std::vector 的移动构造函数(一个接受右值引用的构造函数)将被自动调用您无需再做进一步的工作.

                  If you're using a C++0x-compatible compiler and standard library, you get better performance from the first example without doing anything. The return value of get_vector(_n, _m) is a temporary, and the move constructor for std::vector (a constructor taking an rvalue reference) will automatically be called with no further work on your part.

                  一般来说,非库作者不需要直接使用右值引用;你会自动获得相当大的好处.

                  In general, non-library writers won't need to use rvalue references directly; you'll just reap a decent chunk of the benefits automatically.

                  这篇关于从 C++11 中的函数调用返回 std::vector 的正确方法(移动语义)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Unable to access non-const member functions of objects in C++ std::set(无法访问 C++ std::set 中对象的非常量成员函数)
                  How should a size-limited stl-like container be implemented?(应该如何实现大小受限的 stl 类容器?)
                  Constructing std::function argument from lambda(从 lambda 构造 std::function 参数)
                  STL BigInt class implementation(STL BigInt 类实现)
                  Sync is unreliable using std::atomic and std::condition_variable(使用 std::atomic 和 std::condition_variable 同步不可靠)
                  Move list element to the end in STL(在 STL 中将列表元素移动到末尾)

                      <bdo id='gm3jK'></bdo><ul id='gm3jK'></ul>

                        <small id='gm3jK'></small><noframes id='gm3jK'>

                      • <tfoot id='gm3jK'></tfoot>
                        <i id='gm3jK'><tr id='gm3jK'><dt id='gm3jK'><q id='gm3jK'><span id='gm3jK'><b id='gm3jK'><form id='gm3jK'><ins id='gm3jK'></ins><ul id='gm3jK'></ul><sub id='gm3jK'></sub></form><legend id='gm3jK'></legend><bdo id='gm3jK'><pre id='gm3jK'><center id='gm3jK'></center></pre></bdo></b><th id='gm3jK'></th></span></q></dt></tr></i><div id='gm3jK'><tfoot id='gm3jK'></tfoot><dl id='gm3jK'><fieldset id='gm3jK'></fieldset></dl></div>

                            <tbody id='gm3jK'></tbody>
                          <legend id='gm3jK'><style id='gm3jK'><dir id='gm3jK'><q id='gm3jK'></q></dir></style></legend>