0

我有以下

class Panel {
public:
  std::array<std::array<std::unique_ptr<fb::Block>, Panel::Y>, Panel::X> blocks;
};

我有一个这样的成员函数:

void Panel::processMove() {
  if (move == nullptr) {
    return;
  }
  MoveType type = move->type;
  switch (type) {
    case MoveType::BLOCK_SWITCH: {
      std::unique_ptr<fb::Block> src = blocks[cursor.x][cursor.y];
      std::unique_ptr<fb::Block> dst = blocks[cursor.x + 1][cursor.y];

      if ((src == nullptr) && (dst == nullptr)) {
        break;
      }
      ...
    }
  }

我不知道如何获得对指向项目的临时引用,因为此代码无法编译并出现以下错误:

call to implicitly-deleted copy constructor of 'std::unique_ptr<fb::Block>'

我应该如何获得对指向项目的临时参考?

4

2 回答 2

2

只需将其作为参考:

std::unique_ptr<fb::Block>& src = blocks[cursor.x][cursor.y]
std::unique_ptr<fb::Block>& dst = blocks[cursor.x + 1][cursor.y]

实际上,由于您使用的是 C++11,因此您可以使用auto

auto& src = blocks[cursor.x][cursor.y]
auto& dst = blocks[cursor.x + 1][cursor.y]

或者,如果您知道所有唯一指针都包含指向有效对象的指针,您可以获得对对象本身的引用,完全绕过指针(感谢@ChrisHartman)

fb::Block& src = *(blocks[cursor.x][cursor.y]);
fb::Block& dst = *(blocks[cursor.x + 1][cursor.y]);

//C++11 auto:
auto& src = *(blocks[cursor.x][cursor.y])
auto& dst = *(blocks[cursor.x + 1][cursor.y])
于 2013-02-16T19:05:01.093 回答
0

std::unique_ptr 可以评估为 abool以检查它是否指向对象。

改变这个:

  std::unique_ptr<fb::Block> src = blocks[cursor.x][cursor.y];
  std::unique_ptr<fb::Block> dst = blocks[cursor.x + 1][cursor.y];

  if ((src == nullptr) && (dst == nullptr)) {
    break;
  }

对此:

  std::unique_ptr<fb::Block> &src = blocks[cursor.x][cursor.y];
  std::unique_ptr<fb::Block> &dst = blocks[cursor.x + 1][cursor.y];

  if ( !src && !dst )) {
    break;
  }
于 2013-02-16T19:08:12.920 回答