使用"this"取消引用指针
dereferencing pointers using "this"
我试图以两种方式使用此关键字在我的类中调用变量,但我对第二种方式感到困惑。正确的解引用方式是"(*this)"。然而,我想知道为什么"*"(这个)。"Num"也不对。我用*(this)得到的错误。num是
在'this'中请求成员'num',该成员是指针类型为
class::class(int n): num(n)
{
cout << "num= " << num << endl;
cout << "this->num" << this->num << endl;
cout << "(*this).num" << (*this).num << endl;
}
因为如果你定义了
int i = 9;
int *ptr = &i;
cout<<*(ptr)<<endl;
和调用*(ptr)它工作。但为什么在我的课上不起作用呢?
这只是操作符优先级的问题。二进制点运算符比一元星号运算符具有更高的优先级,因此*(this).num
(括号在那里没有作用)被解释为*(this.num)
,而不是(*this).num
。编译器告诉你,因为this
是一个指针,this.num
没有意义:你不能直接对指针应用点运算符。
您使用了两个操作符:间接/解引用操作符*
和成员访问操作符.
。
如果你看一下这些操作符的优先级,你会发现.
的优先级高于*
(即.
将在*
之前应用),因此*(this).num
基本上与写*(this.num)
相同。
因为this
是一个指针,你不能在它上面使用.
操作符,这也是错误信息告诉你的(尝试使用->
代替)。
第二个示例之所以有效,是因为您没有使用.
操作符,因此没有混淆优先级。
.
优先于*
。
所以写*(this).num
相当于(*((this).num)))
。或*(this.num)
.
你的第二个例子与第一个完全不同,因为没有访问成员.
或->
。
如果你不知道所有的优先级,或者即使你知道,添加适当的括号通常更容易读。
一个可以工作,另一个不能,因为它们不是同一件事!
*(ptr)
和*(this)
是相同的,但*(this).num
和(*this).num
不相同,这就是添加括号的全部意义!它们改变子表达式的分组方式,就像在数学中一样。
(ptr)
和(this)
中的括号是完全多余的,您正在分组单个子表达式,它什么也不做。在(*this)
中,它不是多余的,它确保你解引用指针,所以在(*this).num
中,它首先解引用指针,然后,然后成员访问.num
应用于解引用的结果。
与数学比较:
(1) = 1,同样(ptr)
= ptr
-(1) = -1,同样*(ptr)
= *ptr
但是-(1 + 3)和-(1)+ 3是完全不同的,因为你改变了运算符的顺序
同样,*(this.num)
和(*this).num
也完全不同。
简单来说就是语法。
(ptr)看起来像这样:首先计算expr inside(),然后对结果解引用,在这种情况下是int。这很好,和*ptr一样。
*(这)。Num等于*this。也就是取这个的第Num个元素。这是不正确的,因为"this"是指向当前对象的指针。
(*)。Num表示解引用this,然后获得Num成员
- 如何使用基类指针引用派生类成员
- 将常量指针引用绑定到非常量指针
- 如果非动态变量被指针引用,何时超出范围?
- 转换指针引用的字符串
- 指针引用的生存期(以 C++为单位)
- 从 unique_ptr::get 发送指针作为指针引用进入函数
- 指针/引用的 CLion 格式
- 使用模板专用化来比较指针引用
- 如何保存指向抽象基类的指针/引用,但在 c++ 中仍然可以复制
- C++初始化指针/引用/复制细微差别
- 用数组或指针引用函数?
- 指针范围问题和返回类中封装的指针向量内的指针引用
- 强制转换为指针引用是否会导致未定义的行为
- 访问由 void 指针引用的结构的成员
- C 为什么当先前的步骤引发异常时,std :: shared_ptr的指针引用会被破坏
- 动态指针引用数组由三元运算符返回值,但有异常
- 悬空指向 int 和 char* 常量的指针/引用
- C++ 二维数组和指针引用
- 通过使用指针/引用,在C++中使用向量加快计算速度
- C++非类型模板模板到函数指针/引用