考虑以下示例:
#include <iostream>
class C {
int intArray[2] { 1, 2 };
int *firstElementPt;
public:
int getFirstElement() volatile {
firstElementPt = intArray;
return *firstElementPt;
};
};
int main()
{
volatile C c;
std::cout << c.getFirstElement();
}
这给了我以下编译错误:
In member function 'int C::getFirstElement() volatile':
10:28: error: invalid conversion from 'volatile int*' to 'int*' [-fpermissive]
我是 C++ 新手。我读到将一个实例声明为 volatile 会隐式地使其所有成员变量变为 volatile。我读到将成员函数声明为 volatile 意味着将隐藏的 *this
指针标记为 volatile。那么为什么赋值 firstElementPt = intArray;
仍然不允许并导致 error: invalid conversion from 'volatile int*' to 'int*'
?
最佳答案
Volatility 和 constness 不通过指针传播,但它们确实通过数组传播。所以在类的易变实例中,firstElementPt
本身是易变的,但它指向的东西不是。然而,intArray
元素是易变的。您试图将一个 volatile-pointer-to-a-non-volatile-int 指向一个 volatile int
。这是不允许的。
关于c++: volatile 实例中的 volatile 成员函数-将数组分配给指针是无效转换吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58175814/