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

< cpp‎ | memory‎ | shared ptr
 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++17)

初等字符串转换
(C++17)
(C++17)
 
动态内存管理
智能指针
(C++11)
(C++11)
(C++11)
(C++17 前)
(C++11)
分配器
内存资源
未初始化存储
未初始化内存算法
有制约的未初始化内存算法
垃圾收集支持
杂项
(C++20)
(C++11)
(C++11)
C 库
低层内存管理
 
 
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

参阅

返回存储的指针
(公开成员函数)