我不明白 std::shared_ptr 的 -> 运算符
I Don't Understand The -> Operator For std::shared_ptr
我似乎无法理解它。std::shared_ptr
的->
运算符只返回一个指向成员的指针(假设它是一个类的实例),但同时它可以用来调用方法。。。如何?我们不对->
运算符返回的指针执行任何操作。我们如何调用方法和访问实例变量?如果我有功能等效的东西,比如
T* Get() {
return &t;
}
在std::shared_ptr
中(是的,我确实意识到有一个get()
方法),为什么我不能写:
someSharedPtr.Get()SomeMethod()
这基本上就是
someSharedPtr->SomeMethod()
正在做。。。我很困惑。返回指针如何替代->->
或operator->()->
语法?
返回指针如何替代
->->
或operator->()->
语法?
因为标准是这么说的。
13.5.6[over.ref]定义了一个过载的operator->
来做正确的事情:
如果
T::operator->()
存在并且运算符被过载解析机制选择为最佳匹配函数(13.3),则表达式x->m
被解释为T
类型的类对象x
的(x.operator->())->m
如果没有这样做,那么您就无法实现类似指针的类型,并且具有用户期望的类似指针的x->m
的常见语义。因此,该语言说这就是它所做的,做任何其他事情都会使重载operator->
变得不那么有用。
这实际上允许您将对operator->
的调用链接到任意深度,如果您有一个类似指针的类型,该类型返回一个类似于指针的类型等,直到最终有东西返回一个真正的指针。
相关文章:
- 为什么比较运算符如此快速
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 增量运算符与后缀混淆
- 一个关于在C++中重载布尔运算符的问题
- 运算符C++ "delete []"仅删除 2 个前值
- 模板类无法识别友元运算符
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 关闭||运算符优化
- 通过继承类使用来自不同命名空间的运算符
- C++Cast运算符过载
- 如何使用AngelScript注册SFML Vector2运算符
- 重载元组索引运算符-C++
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- 布尔比较运算符是如何在C++中工作的
- 重载运算符new[]的行为取决于析构函数
- 是否需要使用 - &gt;运算符在C 中调用成员函数时