3

我有以下简单的测试代码。

#include <stack>
#include <iostream>
#include "boost/pool/pool_alloc.hpp"

struct Frame
{
    uint32_t i{};

    Frame(uint32_t _i) : i(_i) {}

    Frame(const Frame& f)
    {
        std::cout << "Copy constructor" << std::endl;
        i = f.i;
    }

    Frame(Frame&& f)
    {
        std::cout << "Move constructor" << std::endl;
        std::swap(i, f.i);
    }
};

int main(int argc, char* argv[])
{
    {
        std::stack<Frame, std::deque<Frame>> stack;

        Frame f(0);
        stack.push(std::move(f)); // Move constructor
        stack.push(Frame(1)); // Move constructor
    }

    {
        std::stack<Frame, std::deque<Frame, boost::pool_allocator<Frame>>> stack;

        Frame f(0);
        stack.push(std::move(f)); // Copy constructor
        stack.push(Frame(1)); // Copy constructor
    }


    return 0;
}

当我使用 Clang 或 GCC 编译此代码时,它会给出以下输出:

Move constructor
Move constructor
Copy constructor
Copy constructor

为什么 using 会boost::pool_allocator阻止编译器使用移动构造函数?
我错过了什么吗?

4

1 回答 1

5

pool_allocator不完善将参数转发到construct: 它只是获取const对值类型的引用并将其作为放置的初始化程序传递new

那是因为pool_allocator尚未针对 C++11 进行更新。

于 2014-12-24T14:09:31.307 回答