"No-throw dereferencing" 标准::unique_ptr
"No-throw dereferencing" of std::unique_ptr
我在C++中编写代码,该代码使用std::unique_ptr u
来处理std::string
资源,并且我想取消引用u
,以便我可以将std::string
传递给std::string
复制构造函数的调用:
std::string* copy = new std::string( /*dereference u here*/ );
我知道new
或std::string
复制构造函数可能会抛出,但这不是我在这里的重点。我只是想知道取消引用u
是否已经会引发异常。我觉得奇怪的是,operator*
没有被标记为noexcept
,而std::unique_ptr
方法get
实际上被标记为noexcept
。换句话说:
*( u.get() )
是作为一个整体noexcept
*u
不是。这是标准的缺陷吗?我不明白为什么会有区别。有什么想法吗?
unique_ptr::operator*()
可能涉及调用存储在unique_ptr
中的类型的operator*()
重载。注意,存储在unique_ptr
中的类型不一定是裸指针,你可以通过嵌套类型D::pointer
来更改类型,其中D
是unique_ptr
的删除器的类型。这就是为什么该功能不noexcept
的原因。
此警告不适用于您的用例,因为您将std::string *
存储在unique_ptr
中,而不是某种使operator*
过载的类型。因此,该电话实际上为您noexcept
。
相关文章:
- 为什么 std::unique 不调用 std::sort?
- CLANG 编译器 说:变量"PTR"可能未初始化
- 在以唯一ptr为值的C++映射中,动态内存何时会被销毁
- 将 ptr 传递给 ptr 到 A 作为参数传递给 A 的函数是不好的做法吗?
- 为共享 ptr 向量实现复制 c'tor?
- 字符和整数中 **(ptr+1) 的值差异
- C++:在不中断共享的情况下通过引用传递共享 PTR?
- 生成"unique"矩阵
- 如何将派生类从基 ptr 分配给 nlohmann::json
- 引用 std::shared:ptr 以避免引用计数
- 我对 std::unique(算法)C++有问题
- 为什么我不能在不进行任何转换的情况下将浮点数放入任何类型的 ptr 中?
- 在调用函数时,ptr** 和 ptr*& 之间是否有区别,或者首选C++?
- 另一种类型的智能ptr,比如具有弱refs的unique_ptr
- 尝试打印出 *ptr++ 的值,以了解它是如何工作的
- 如何控制共享 ptr 引用计数?
- std::shared_ptr::unique(),复制和线程安全
- 如何在C++03中用自定义谓词调用std::unique
- C++中的指针否定 (!ptr == NULL)
- C++14 unique_ptr并使用已删除的函数'std::unique-ptr' unique_ptr错误