std::experimental::optional<T>::operator->, std::experimental::optional<T>::operator*

来自cppreference.com
 
 
实验性
技术规范
文件系统库 (文件系统 TS)
库基础 (库基础 TS)
库基础 2 (库基础 TS v2)
库基础 3 (库基础 TS v3)
并行扩展 (并行 TS)
并行扩展 2 (并行 TS v2)
并发扩展 (并发 TS)
并发扩展 2 (并发 TS v2)
概念 (概念 TS)
范围 (范围 TS)
反射 (反射 TS)
数学特殊函数 (特殊函数 TR)
实验性非 TS 功能特性
模式匹配
线性代数
std::execution
契约
2D 图形
 
 
 
constexpr const T* operator->() const;
(1) (库基础 TS)
constexpr T* operator->();
(1) (库基础 TS)
constexpr const T& operator*() const&;
(2) (库基础 TS)
constexpr T& operator*() &;
(2) (库基础 TS)
constexpr const T&& operator*() const&&;
(2) (库基础 TS)
constexpr T&& operator*() &&;
(2) (库基础 TS)

访问所含值。

1) 返回指向所含值的指针。
2) 返回到所含值的引用。

如果 *this 不含有值则其行为未定义。

参数

(无)

返回值

指向所含值的指针或引用。

异常

不抛出。

注解

此运算符并不检查 optional 是否含有值。如果需要带检查访问,可以使用 value()value_or()

示例

#include <experimental/optional>
#include <iostream>
#include <string>
using namespace std::literals;
 
int main()
{
    std::experimental::optional<int> opt1 = 1;
    std::cout << *opt1 << '\n';
 
    std::experimental::optional<std::string> opt2 = "abc"s;
    std::cout << opt2->size() << '\n';
}

输出:

1
3

参阅

返回所含值
(公开成员函数)
如果有则返回所含值,否则返回另一个值
(公开成员函数)