命名空间
变体
操作

std::unique_ptr<T,Deleter>::operator*, std::unique_ptr<T,Deleter>::operator->

来自 cppreference.com
< cpp‎ | memory‎ | unique ptr
 
 
实用程序库
语言支持
类型支持 (基本类型,RTTI)
库特性测试宏 (C++20)
动态内存管理
程序实用程序
协程支持 (C++20)
可变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用实用程序
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
通用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
基本字符串转换
(C++17)
(C++17)

 
动态内存管理
未初始化内存算法
受限的未初始化内存算法
分配器
垃圾回收支持
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)



 
 
typename std::add_lvalue_reference<T>::type operator*() const
    noexcept(noexcept(*std::declval<pointer>()));
(1) (自 C++11 起)
(自 C++23 起为 constexpr)
pointer operator->() const noexcept;
(2) (自 C++11 起)
(自 C++23 起为 constexpr)

operator*operator-> 提供对 *this 所拥有的对象的访问。

如果 get() == nullptr,则行为未定义。

这些成员函数仅针对 unique_ptr 提供,用于单个对象,即主模板。

内容

[编辑] 参数

(无)

[编辑] 返回值

1) 返回 *this 所拥有的对象,等效于 *get()
2) 返回指向 *this 所拥有的对象的指针,即 get()

[编辑] 异常

1) 如果 pointer 具有抛出异常的 operator*,则可能抛出异常。

[编辑] 备注

使用 std::add_lvalue_reference 的目的是为了能够实例化 std::unique_ptr<void>,因为在 C++ 中不允许使用 void&,而 std::add_lvalue_reference<void> 会生成 void。有关详细信息,请参阅 LWG673

[edit] 示例

#include <iostream>
#include <memory>
 
struct Foo
{
    void bar() { std::cout << "Foo::bar\n"; }
};
 
void f(const Foo&) 
{
    std::cout << "f(const Foo&)\n";
}
 
int main() 
{
    std::unique_ptr<Foo> ptr(new Foo);
 
    ptr->bar();
    f(*ptr);
}

输出

Foo::bar
f(const Foo&)

[edit] 缺陷报告

以下行为更改的缺陷报告已追溯应用于先前发布的 C++ 标准。

DR 应用于 已发布的行为 正确行为
LWG 2762 C++11 operator* 可能引发异常,即使
*get() 是 noexcept
添加了条件异常说明

[edit] 另请参阅

返回指向托管对象的指针
(公共成员函数) [edit]