1

我有一个带有两个类的 C++ Qt 静态库 - dataprocthreadcalcvalue。在第一个中,当我从calcvalue的实例调用方法时,指针this(引用dataprocthread类)突然变为null.

这是dataprocthread.h

class DataProcThread : public QThread
{
    Q_OBJECT

    public:
        DataProcThread(int sarray[9], int val);

    signals:
        workDone(int result);

    private:            
        int _sarray[9];
        int _val;
        void run();
};

dataprocthread.cpp

DataProcThread::DataProcThread(int sarray[9], int val)
{
    for (int x = 0; x < 9; x++)
    {
        _sarray[x] = sarray[x];
    }
    _val = val;
}

void DataProcThread::run()
{
    CalcValue* cv = new CalcValue();
    int myval = 0;
    for (int i = 0; i < 100; i++)
    {
        myval = cv->processData(this->_val);
        if (this->_sarray[0] != myval)
        {
            //do something
        }
    }
    emit workDone(intValue);
}

计算值.h

class CalcValue
{
    public:
        CalcValue();
        int processData(int someval);
};

计算值.cpp

CalcValue::CalcValue()
{
}

int processData(int someval)
{
    //do something and return int value
}

当我运行此代码时,它突然收到信号“分段错误”。使用调试器,我发现DataProcThread::run()函数中的问题:当我调用cv->processData函数时,一切正常。但是在下一行 ( if (this->_sarray[0] != myval)) 上,this指针变为null(我可以在 Locals 窗口中看到它),因此,我无法访问this->_sarray变量。

如果它很重要,这就是我启动线程的方式(从我的库之外的另一个类):

DataProcThread* thread = new DataProcThread(sarray, val);
QObject::connect(thread, SIGNAL(workDone(int)), this, SLOT(collectWork(int)));
thread->start();

我做错了什么?

4

1 回答 1

2

正如评论中指出的那样,问题发生在processData函数中:它正在写入内存。

我只是使用strncpy而不是strcpy问题消失了(是一个很好的解释)。

于 2013-04-02T09:07:20.647 回答