类成员函数在声明为const后修改类成员变量
class member function altering class member variables after they were declared const
考虑以下代码(不完全是我使用的,但只是为了突出问题)
class Pointarr //creates an array of points which can be recalled by object
{
public:
Pointarr(int, int, bool);
~Pointarr(){};
mutable Point array[];
private:
void fillarray(int) const;
int const minpix;
int const mirrors;
bool const canvasfeed;
};
void Pointarr::fillarray(int mirrors) const
{
Point zero(0,0);
for(int i = 0; i < mirrors; i++)
{
array[i] = zero;
}
}
Pointarr::Pointarr(Mat dt, int mpx, int mir, bool cf) : dot(dt), minpix(mpx), mirrors(mir), canvasfeed(cf)
{
fillarray(mirrors);
}
我将得到一些东西先出来的方式,我在linux上使用gcc c++编译器。我正在使用OpenCV库,其中点是一种变量类型,它以(x,y)的格式保存坐标。我相信它只是在内存中使用了足够的空间来容纳每个数字,所以对于两个整数,x为4字节,y为4字节。
我遇到的问题是,在构造函数声明(Pointarr())中的变量初始化正确,我确认了这一点,但是当我调用fillarray(int)函数填充数组与零值的负载,(0,0),它导致变量镜像和minpix都改变为0,其中canvasfeed保持原样,但这只是当镜像等于1。
现在,让我们指定一些东西,你会注意到当镜像为1时,填充数组内的循环只运行一次,这意味着数组只有一个值(一个点)。如果我将镜像设置为2,那么canvasfeed也变为0。我认为这是相当清楚的,fillarray函数是分配相同的内存用于保存我的私有变量到数组,因此正在改变我的私有变量。这是一个问题,因为我需要他们稍后。
问题是,我被引导相信使私有变量const意味着编译器会抱怨,如果在任何时候变量被改变,但它在这种情况下编译得很好,如果我是诚实的,虽然我不完全理解const应该如何使用(几乎)。
所以最后的问题是,我如何避免使数组使用我需要的其他内存,但仍然初始化它具有相同数量的元素槽作为镜像。
我被引导相信使私有变量为const意味着编译器在任何时候改变变量都会报错。
要么你误解了,要么你被误导了。有许多方法可以修改固有的const
成员,而编译器甚至可能无法检测到它。最终,尽管这会导致未定义的行为。
你要确保你永远不会直接或间接地修改一个固有的const
数据成员。
mutable Point array[];
被称为Point
类型的不完全数组,它保证只存储一个元素。当您使用它来存储更多元素时,您最终写入超出数组的边界,导致未定义行为。
你需要使用一个向量:
mutable std::vector<Point> array;
- 将成员变量添加到共享库中的类中,不会破坏二进制兼容性吗
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 内置函数可查看CPP中的成员变量
- 是否可以初始化不可复制类型的成员变量(或基类)
- 将包含C样式数组的对象初始化为成员变量(C++)
- 为什么我不能在一个类的不同行中声明和定义成员变量?
- 在循环中按顺序遍历成员变量
- c++类声明时,相同的例程,不同的成员变量类型
- 如何从另一个文件继承私有成员变量和公共函数
- 在C++类中,是否必须初始化作为数组的成员变量
- 如何从子成员函数修改父公共成员变量
- 我可以在 C++ 中将数据成员/变量从其定义之外添加到结构中吗?
- 从私有成员变量的成员方法返回unique_ptr
- 在派生类中使用基类的私有成员变量的最佳方法
- 静态 constexpr 类成员变量对多线程读取是否安全?
- C++:是否可以使用非静态成员变量模板?
- 打印所有继承的类成员变量和方法
- 如何在复杂继承中访问静态成员变量
- 为什么我不能在返回 const 的布尔函数中为类成员变量赋值?C++
- 成员变量与函数概念检查