如果使用非易失性对象调用易变成员函数,会发生什么?
#include <iostream>
using namespace std;
class A
{
private:
int x;
public:
void func(int a) volatile //volatile function
{
x = a;
cout<<x<<endl;
}
};
int main()
{
A a1; // non volatile object
a1.func(10);
return 0;
}
答案 0 :(得分:7)
规则与const
成员函数相同。可以在非volatile
对象上调用volatile
成员函数,但不能在volatile
对象上调用非volatile
成员函数。 / p>
对于您的情况,A::func()
将被调用。如果使它们相反,则编译将失败。
class A
{
private:
int x;
public:
void func(int a) // non-volatile member function
{
x = a;
cout<<x<<endl;
}
};
int main()
{
volatile A a1; // volatile object
a1.func(10); // fail
return 0;
}
答案 1 :(得分:4)
您可以像非const对象上的const
函数一样调用它,但出于不同的原因。
volatile
限定符使隐式this参数被视为指向volatile对象的指针。
基本上,这意味着在访问对象的数据成员时将应用volatile对象的语义。对x
的任何读取都无法进行优化,即使编译器可以证明在上次读取后没有最近的写入。
当然,如果对象不是真正易变的,func
的主体仍然是正确的,尽管没有尽可能优化。所以你可以称它为好。