• 6282阅读
  • 1回复

[讨论]关于Qt主线程和次线程的一点疑惑 [复制链接]

上一主题 下一主题
离线小意达
 
只看楼主 倒序阅读 楼主  发表于: 2012-05-17
       最近比较关注qt的线程。看了http://apps.hi.baidu.com/share/detail/23550552 这篇文章后,才发现自己以前对qt的多线程认识是错的!比如自己写一个qthread子类,除了run()这个函数是在次线程执行的,其它函数都是在主线程被调用的,因为qthread类就是一个qobject,它是在主线程创建的,自然它的那些非run()函数以及各种数据成员都属于主线程。
      我自己写了个小的测试程序,分别在主线程中实例化QThread子类对象、QObject子类对象、以及一个自己定义的基类对象,然后在这些对象构造函数里分别打印当前的QthreadId。在主线程中定义的对象自然应该和主线程id一致,可是结果却并非如此:
Object/ObjectNew是我定义的两个继承自QObject类的子类,它们都在各自的构造函数里打印当前线程的id,比如
  1. Object::Object(QObject *parent) :
  2. QObject(parent)
  3. {
  4.     cout<<"obj construct:"<<QThread::currentThread()<<endl;
  5. }

   Worker类继承自QThread类,我分别让它在构造函数和run()函数中打印当前的threadid。
  1. Worker::Worker(QObject *parent) :
  2. QThread(parent)
  3. {
  4.    cout<<"work thread construct:"<<QThread::currentThreadId()<<endl;
  5. }
  6. void Worker::run()
  7. {
  8.     cout<<"thread running:"<<QThread::currentThreadId()<<endl;
  9.     exec();
  10. }

   然后还定义了一个无父类的类A,让它在构造函数里打印当前线程id:
  1. A::A()
  2. {
  3.    cout<<"A instance construct"<<QThread::currentThreadId()<<endl;
  4. }

   最后我在main函数中实例化这些类的对象
  1. int main(int argc, char *argv[])
  2. {
  3. QCoreApplication a(argc, argv);
  4. cout<<"main thread:"<<QThread::currentThreadId()<<endl;
  5. Worker worker;
  6. worker.start();
  7. ObjectNew objnew;
  8. Object obj;
  9. A b;
  10. return a.exec();
  11. }

    运行结果截图:


    其中main函数所在的线程id(主线程id)和worker、A类的对象所打印的线程id一致,都是0Xa80,worker在调用start()后会运行run(),此时打印的线程id是次线程id 0X140。不过让我不解的是为什么继承自QObject的两个对象打印出的线程id却和主线程id不一样,是0X3b29f8?难道这两个类的对象不是在主线程创建的吗?求达人解答下






离线largep
只看该作者 1楼 发表于: 2012-05-19
Object::Object(QObject *parent) :
QObject(parent)
{
    cout<<"obj construct:"<<QThread::currentThread()<<endl;
}
QThread::currentThread()不是QThread::currentThreadId()
快速回复
限100 字节
 
上一个 下一个