从引用创建SHARED_PTR

2022-05-12 00:00:00 c++ shared-ptr

我对C++比较陌生,这个问题听起来像个初学者问题,但我无法用Internet上的其他资源解决它。

我正在尝试从引用创建一个Shared_PTR。我有以下Book类:

#include <memory>
#include "Author.hpp"

class Book
{
   public:
      void setAuthor(const Author& t_author);

   private:
      std::shared_ptr<Author> m_author;
}

这是我的Author类:

#include <memory>
class Book;

class Author
{
   public:
      void addBook(const Book& t_book);

   private:
      std::vector<std::weak_ptr<Book>> m_books;
}

我尝试这样实现Book::setAuthor方法:

void Book::setAuthor(const Author& t_author)
{
   m_author = std::shared_ptr<Author>(&t_author);
}

但如果我尝试编译这段代码,得到的结果是:

从常量作者*到作者*的转换无效

从sizeof到const作者的转换无效

您能告诉我我的代码出了什么问题吗?我也尝试了与WARKE_PTR相同的方法,但也不起作用。


解决方案

虽然您的错误源于以下事实:正在使用的std::shared_ptr<Author>构造函数需要Author*,但表达式&t_author会导致对象类型为const Author*


另一件错误的事情:

void Book::setAuthor(const Author& t_author)
{
   m_author = std::shared_ptr<Author>(&t_author);
}

想象一下调用book.setAuthor(Author("Herb Sutter"));,您将有一个悬空指针,因为t_author将在该函数完成后不复存在。


您需要将对象复制或移动到std::shared_ptr实例中。尽可能使用std::make_shared<T>创建std::shared_ptr<T>对象。

void Book::setAuthor(const Author& t_author)
{
   m_author = std::make_shared<Author>(t_author);
}

更好:

void Book::setAuthor(Author t_author)
{
   m_author = std::make_shared<Author>(std::move(t_author));
}

相关文章