std::shared_ptr::operator*, std::shared_ptr::operator->

来自cppreference.com
< cpp‎ | memory‎ | shared ptr
 
 
工具库
类型支持(基本类型、 RTTI 、类型特性)
动态内存管理
错误处理
程序工具
变参数函数
日期和时间
函数对象
(C++11)
关系运算符
optionalanyvariant (C++17)
pair 与 tuple
(C++11)
(C++17)
swap 、 forward 与 move
(C++14)
(C++11)
(C++11)
初等字符串转换
(C++17)
(C++17)
类型运算
(C++11)
(C++17)
 
动态内存管理
 
 
T& operator*() const noexcept;
(1)
T* operator->() const noexcept;
(2)

解引用所存储的指针。若存储的指针为空,则行为未定义。

目录

[编辑] 参数

(无)

[编辑] 返回值

1) 解引用存储的指针所得的结果,即*get()

2) 存储的指针,即get()

[编辑] 提醒

T是(可有cv限定的)void类型时,是否声明函数(1)是未指定的。

T是数组类型时,是否声明这两个函数是未指定的。

(C++17 起)

以上情况下,若函数被声明,则其返回类型是未指定的,但函数声明保证合法,函数定义未必合法。这使得std::shared_ptr<void>可以实例化。

[编辑] 示例

#include <iostream>
#include <memory>
 
struct Foo
{
   Foo(int in) : a(in) {}
   void print() const
   {
      std::cout << "a = " << a << '\n';
   }
   int a;
};
 
int main()
{
   auto ptr = std::make_shared<Foo>(10);
   ptr->print();
   (*ptr).print();
}

输出:

a = 10
a = 10

[编辑] 另请参阅

返回存储的指针
(公开成员函数) [编辑]