没有标准的方法来比较智能指针和常规指针
No standard way to compare smart pointer with regular pointer?
为什么C++标准不包括比较运算符来比较智能指针(unique_ptr、shared_ptr…)和常规指针(t*)?
Tom
更新我不想知道如何做到这一点。问题是为什么它没有被定义为C++标准的一部分?对于unique_ptr和shared_ptr,这样的定义是微不足道的。
这方面的用例如下:类A有一个带有unique_ptr键的映射。unique_ptr用于内存管理。当类a的用户传递了一个常规指针时,将在此映射中执行查找。不幸的是,该标准没有定义比较运算符。
为什么C++标准不包括比较运算符来比较智能指针(unique_ptr、shared_ptr…)和常规指针(t*)?
这一决定背后的原则通常被称为"使您的界面易于正确使用,而难以/不可能错误使用"。
从概念上讲,智能指针和原始指针是不同的。
智能指针会施加限制(即"unique_ptr是一个指针,但不能有多个副本")。尽管它们的行为类似于指针(指向一个点——如果你可以原谅双关语的话),但它们有不同的语义。
也就是说,如果你有:
int *p1 = new int{5};
std::unique_ptr<int> p2{new int{5}};
p1 == p2.get();
这种比较很容易做,很明确,而且很明显你在比较苹果和苹果(很容易理解发生了什么——你在与原始指针的值进行比较)。
另一方面,使用自定义比较运算符会引发奇怪的问题("unique_ptr是唯一的;你怎么能将它与其他东西进行比较?-如果它是唯一的,它应该总是不同的")。
你可以只做smart_ptr.get() == raw_ptr
,这有什么错?
因为比较运算符不比较所指向的内容,只比较实际的指针。由于智能指针拥有实际原始指针的"所有权",任何其他原始指针都不能与智能指针相同。
主要原因可能是标准智能指针,不应该有任何原始指针对象。有一个指向对象的原始指针几乎保证在维护过程中的某个时刻,有人会最终从中创建了第二个智能指针后果。(一个例外是空指针标准不允许与空指针常量进行比较。)
- 1d 智能指针不适用于语法 (*)++
- 优先顺序:智能指针和类析构函数
- 对于C++中使用智能指针的指针算术限制,有没有一种变通方法
- 智能指针作为无序映射键,并通过引用进行比较
- 智能指针概念所有权和寿命
- 正在理解智能指针,但出现错误:未分配正在释放的指针
- 尝试使用智能指针时引发异常
- 我可以制作指向智能指针的智能指针吗?
- 通过智能指针和转换对基本模板参数进行模板推导
- OpenCV 我应该使用智能指针来防止内存泄漏吗?
- 从堆栈分配的原始指针构造智能指针
- 初始化指向类实例的智能指针并访问其方法
- 如何使用 std::make_shared 创建基类类型的智能指针?
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 编译器不会使用 -std=c++11 编译智能指针
- 具有智能指针的多态性
- C++:矢量分配器行为、内存分配和智能指针
- 通过简单的包装指针C++智能指针性能和差异
- 矢量中的自动指针(智能)
- Std::vector的对象/指针/智能指针传递对象(总线错误:10)