复制"struct atomic"的构造函数

Ahm*_*d A 3 c++ templates c++11

我有以下代码:

enum class State : uint32_t
{
    FREE,
    IDLE,
    COAST,
    MOVE,
    STOP
};

std::atomic<State> car1_state = State::IDLE;  <--- Line a
std::atomic<State> car2_state(State::IDLE);   <--- Line b
Run Code Online (Sandbox Code Playgroud)

以下是原子头文件的片段:

// c++ header file - atomic
template<typename _Tp>
  struct atomic
  {
  private:
    _Tp _M_i;

  public:
    atomic() noexcept = default;
    ~atomic() noexcept = default;
    atomic(const atomic&) = delete;                <--- Line c
    atomic& operator=(const atomic&) = delete;
    atomic& operator=(const atomic&) volatile = delete;

    constexpr atomic(_Tp __i) noexcept : _M_i(__i) { }    <--- Line d

    operator _Tp() const noexcept
    { return load(); }

    operator _Tp() const volatile noexcept
    { return load(); }

    _Tp
    operator=(_Tp __i) noexcept
    { store(__i); return __i; }
....
Run Code Online (Sandbox Code Playgroud)

我有几个问题:

  • 线b编译罚款.我在线d中理解构造函数被调用.对?
  • 线路a编译失败.根据错误消息,调用行c中的复制构造函数,因此错误消息"使用已删除的函数"(我理解).

有人可以帮我理解为什么/如何线路a最终呼叫线路c(而不是线路d).

Ker*_* SB 5

复制初始化需要可访问的非显式复制或移动构造函数,因为它正式初始化来自相同类型的临时prvalue的变量.那是,

Foo a = x;
Run Code Online (Sandbox Code Playgroud)

相当于:

Foo a = Foo(x);
Run Code Online (Sandbox Code Playgroud)

您的类型没有可访问的复制构造函数,因此出错.相比之下,直接初始化不需要复制构造函数:

Foo a(x);
Run Code Online (Sandbox Code Playgroud)