我开始理解使用线程的机制,但我想我已经卡住了,
如果我理解,我必须创建自己的类,释放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();
}
答案 0 :(得分:3)
这是一篇关于在Qt中使用线程的好文章 http://qt-project.org/doc/qt-5.0/qtcore/thread-basics.html
答案 1 :(得分:0)
有几种方法可以解决这个问题。如上所述,您可以使用互斥锁。使用QByteArray
(例如void something(QByteArray)
)参数或QThreadStorage
的排队连接都是可行的解决方案,但前者更简单,可能最适合您的情况。
此外,永远不要继承QThread
。请改用QObject
和moveToThread()
。 QThread
驻留在主线程中,只管理它创建的线程。如果在使用moveToThread()
之前将信号连接到对象,请务必使用Qt::QueuedConnection
中的QObject::connect()
参数。