[英]Calling volatile member function using not volatile object in C++
如果使用非volatile对象调用volatile成员函数会发生什么?
#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;
}
该规则与const
成员函数相同。 可以在非易失volatile
对象上调用volatile
成员函数,但是不能在volatile
对象上调用非易失volatile
成员函数。
对于你的情况, 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;
}
您可以像非const对象上的const
函数一样调用它,但原因各不相同。
volatile
限定符使隐式this参数被视为指向volatile对象的指针。
实质上,这意味着在访问对象的数据成员时将应用易失性对象的语义。 即使编译器可以证明在最后一次读取之后没有最近的写入,也无法对x
任何读取进行优化。
当然,如果对象不是真正易变的,那么func
的主体仍然是正确的,尽管没有尽可能优化。 所以你可以称它为好。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.