mFe*_*ein 10 c++ qt qvector qtcore
我是c ++和Qt的新手,我正在尝试初始化一个QVector,它是类初始化列表中的类成员,如:
MyClass::MyClass(QWidget *parent) : QMainWindow(parent) , myVector(QVector<double>(100))
Run Code Online (Sandbox Code Playgroud)
我期待QVector已经有100个索引,但是当我尝试读取时,myVector[0]我得到一个断言错误,说"test.exe中的0x0143bf77处的未处理异常:0xC0000005:访问冲突读取位置0x00000004." 程序在Qt的这一行停止:
inline T &QVector<T>::operator[](int i)
{ Q_ASSERT_X(i >= 0 && i < d->size, "QVector<T>::operator[]", "index out of range");
return data()[i]; }
Run Code Online (Sandbox Code Playgroud)
我相信这表明我正在尝试访问尚未分配的成员,所以我想我没有正确使用初始化列表.我可以把它作为一个指针并new QVector(100)在构造函数中创建一个但我想知道什么是错的,我怎么能使它正确.
lpa*_*app 11
您可能做错了未显示的事情,因为以下代码对我来说很好,它应该是设计的.请注意,对于第一个元素,您可以使用方便的第一个方法.
#include <QVector>
#include <QDebug>
int main()
{
QVector<double> myVector(QVector<double>(100));
qDebug() << "TEST FIRST:" << myVector.first();
return 0;
}
Run Code Online (Sandbox Code Playgroud)
TEMPLATE = app
TARGET = main
SOURCES += main.cpp
Run Code Online (Sandbox Code Playgroud)
TEST FIRST: 0
Run Code Online (Sandbox Code Playgroud)
正如我在评论中提到的,您可以使用保留方法.
void QVector :: reserve(int size)
尝试为至少大小的元素分配内存.如果你事先知道向量的大小,你可以调用这个函数,如果你经常调用resize(),你可能会获得更好的性能.如果大小被低估,那么最糟糕的情况是QVector会慢一点.
此功能的唯一目的是提供一种微调QVector内存使用的方法.通常,您很少需要调用此函数.如果要更改向量的大小,请调用resize().
所以,你会写这样的东西:
MyClass::MyClass(QWidget *parent)
: QMainWindow(parent)
{
myVector.reserve(100);
}
Run Code Online (Sandbox Code Playgroud)
但是,正如我后面在注释中所述,简单的构造函数也应该像:
MyClass::MyClass(QWidget *parent)
: QMainWindow(parent)
, myVector(100)
{
}
Run Code Online (Sandbox Code Playgroud)
你正在做的是调用复制构造函数(虽然对于一个隐式共享类),所以它可能会慢一点.它至少比您需要的代码多.