从引用创建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));
}
相关文章