假设我有以下的类:
struct A{
void method(A& otherA) const{
/* Mutate otherA */
}
};
然后我有了这个:
A myA;
myA.method(myA);
我已经告诉编译器
method
不会改变this
实例,但是编译器是否意识到我可以将this
实例作为参数传递?这样做会破坏一些东西吗?这是定义好的行为吗?假设我有以下的类:
struct A{
void method(A& otherA) const{
/* Mutate otherA */
}
};
然后我有了这个:
A myA;
myA.method(myA);
method
不会改变this
实例,但是编译器是否意识到我可以将this
实例作为参数传递?这样做会破坏一些东西吗?这是定义好的行为吗?这完全没有问题。在本例中,您所做的有时被称为“别名”——当两个参数实际上指向同一个对象时。
考虑在普通C中更简单的情况:
void foo(int* a, const int* b) { *a += *b; }
那个函数接受两个指向 int
的指针,并将第二个指针加到第一个指针上。当然,使用我的 foo
函数的这段代码是完全有效的:
int x = 10;
foo(&x, &x); // now x is 20
如果您不喜欢这种情况下的行为,最好的方法可能是在您的方法中添加一个检查,例如:
如果您不喜欢这种情况下的行为,最好的方法可能是在您的方法中添加一个检查,例如:
void A::method(A& otherA) const {
if (this == &otherA) { /* aliasing detected */ }
else { /* proceed as normal */ }
}
const
。 - songyuanyaoconst
表示对象在方法内不会被通过this->
改变,但仍可能会被其他方式改变。 - M.M