3

我开始了解使用线程的机制,但我想我被卡住了,

如果我理解的话,我必须创建自己的类,释放run()方法,然后创建线程。

问题是我的线程必须从gui(主线程)读取一些变量,并且使用它们,它将创建一些其他变量,主窗口将读取和绘制这些变量。

问题是我正在接收蓝牙连接,它必须在线程中始终处于活动状态,但 gui 必须绘制从该线程读取的值。

这是需要在单独线程上的函数:

// Listen to the device for data
void gui::listen_device()
{
    unsigned char buf[10];
    unsigned char crcval;
    fd_set readmask;
    struct timeval tv;

    tv.tv_sec = 0;
    tv.tv_usec = 28000;

    memset (buf, 0, 10);

    int v = 0, v1 = 0, v2 = 0;

    while(1)
    {
        int i;
        FD_ZERO (&readmask);
        FD_SET (sock, &readmask);
        if (select (255, &readmask, NULL, NULL, &tv) > 0)
        {
            if (FD_ISSET (sock, &readmask))
            {
                int numb;
                numb  = 0;

                numb = recv (sock, buf, 10, MSG_WAITALL);

                crcval = BP_CRC8 (buf, 9);

                // 8 bits
                if (ui->comboBox->currentIndex() == 0)
                {
                    if (crcval == buf[9])
                    {
                        s++;
                        // Print of counter
                        printf ("%d ->", buf[0]);
                        fprintf (data, "%d,", buf[0]);

                        for (int i = 1; i < 9; i++)
                        {
                            v = buf[i];
                            printf ("%d,", v);
                            fprintf (data, "%d,", v);
                        }

                        printf ("\n");
                        fprintf (data, "\n");

                        //fprintf(data, "s: %d, f: %d\n", s,f);
                    }

                    else
                    {
                        f++;
                    }

                }

                // 12 bits
                else if (ui->comboBox->currentIndex() == 1)
                {
                    if (numb == 14)
                    {
                        // Print of counter
                        printf ("%d,", buf[0]);
                        fprintf (data, "%d,", buf[0]);
                        for (i = 1; i < numb - 1; i += 3)
                        {
                            v1 = buf[i] | ((buf[i + 1] & 0x0F) << 8);
                            v2 = buf[i + 2];
                            v2 = (v2 << 4) | ((buf[i + 1] & 0xf0) >> 4);
                            printf ("%d,%d,", v1, v2);
                            fprintf (data, "%d,%d,", v1, v2);
                        }

                        printf ("\n");
                        fprintf (data, "\n");
                    }
                }
            }
        }
    }
}

并且这里读取的一些变量是全局的,如sock, data, and the ui->combobox.

我希望buf与主窗口共享。

有什么建议吗?

更新:

为什么这是错的?

void QMyThread::run()
{
    listen_device();
}
4

2 回答 2

5

这是一篇关于在 Qt http://qt-project.org/doc/qt-5.0/qtcore/thread-basics.html中使用线程的好文章

于 2013-03-06T14:21:22.900 回答
0

有几种方法可以解决这个问题。如前所述,您可以使用互斥锁。带有QByteArray(例如void something(QByteArray))参数的排队连接或者QThreadStorage都是可行的解决方案,尽管前者更简单并且可能最适合您的情况。

另外,永远不要子类QThread。使用QObjectandmoveToThread()代替。QThread驻留在主线程中并简单地管理它创建的线程。如果在使用 之前将信号连接到对象moveToThread(),请确保使用 中的Qt::QueuedConnection参数QObject::connect()

于 2015-04-02T14:28:30.797 回答