在子线程中创建子线程及线程查看方法

109 篇文章 12 订阅
72 篇文章 19 订阅

方式一、孙线程在son线程中阻塞回收 

#include <unistd.h>
#include <stdio.h>
#include <pthread.h>
pthread_t pid_1,pid_2;
void *func2(void *arg)
{
    while(1)
    {
        printf("this is grandson\n");
        sleep(1);
    }
}
void *func1(void *arg)
{
    pthread_create(&pid_2,NULL,func2,NULL);

    printf("this is son\n");
    sleep(10);
    pthread_join(pid_2,NULL);
    printf("func1--son exit \n");

}

int main(int argc, char *argv[])
{
    pthread_create(&pid_1,NULL,func1,NULL);

    pthread_join(pid_1,NULL);
    printf("main--son exit \n");
   // pthread_join(pid_2,NULL);
    printf("father exit\n");
    return 0;
}

 方式二:孙线程在主线程中阻塞回收

#include <unistd.h>
#include <stdio.h>
#include <pthread.h>
pthread_t pid_1,pid_2;
void *func2(void *arg)
{
    while(1)
    {
        printf("this is grandson\n");
        sleep(1);
    }
}
void *func1(void *arg)
{
    pthread_create(&pid_2,NULL,func2,NULL);

    printf("this is son\n");
    sleep(10);
//    pthread_join(pid_2,NULL);
    printf("func1--son exit \n");

}

int main(int argc, char *argv[])
{
    pthread_create(&pid_1,NULL,func1,NULL);

    pthread_join(pid_1,NULL);
    printf("main--son exit \n");
    pthread_join(pid_2,NULL);
    printf("father exit\n");
    return 0;
}

小结:我们看到,son线程的退出,并没有影响到孙线程的运行,因为进程并未退出。 

查看线程的方法:参考该文

以上述方式一的形式查看线程:

  总结:

1)同一进程中的线程是平等的,没有父子之分。当然也包括所谓的主线程、在主线程中创建的线程、在所谓的子线程中创建的线程。

线程既然是平等的,只要进程不退出,倘若son线程退出,我们看到不会影响到孙线程的运行。

2)孙线程在子线程中创建,可以理解为,启动孙线程的顺序点是在此时,而并非在主线程中。

也就是说,我们可以在任意我们需要创建一个平行任务的地方,创建一个子线程,而并非得在主线程中创建。

3)线程函数,其实,就可以理解为就是一个函数(当然单独调用也能用),与普通函数不同的是,线程函数能够与其他函数并行(同时执行,而非线程函数只能顺序执行。)

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
是的,QT框架支持在子线程创建线程。QT提供了多种方式来创建和管理线程,包括使用QThread类。 首先,你需要创建一个继承自QThread的类。这个类需要重写一些方法,例如`run()`方法,这个方法会在新线程运行。然后,你可以创建这个类的实例,并调用其`start()`方法来启动新线程。 下面是一个简单的示例: ```cpp #include <QThread> #include <QDebug> class MyThread : public QThread { Q_OBJECT public: void run() override { // 在这里编写线程需要执行的代码 qDebug() << "Running in my thread..."; } }; int main(int argc, char *argv[]) { QCoreApplication a(argc, argv); MyThread thread; thread.start(); // 启动新线程 return a.exec(); } ``` 在这个例,我们创建了一个新的线程`MyThread`,并在其运行了一个简单的打印语句。然后我们通过调用`thread.start()`来启动这个新线程。注意,调用`start()`后线程就开始运行,但是我们无法在此线程上调用QT的任何其它函数(比如主窗口等)。如果需要在新线程上调用这些函数,你可能需要将它们包装在某个任务(比如任务队列或信号槽机制)。 如果你需要在子线程创建线程,那么你可以在`run()`方法调用`QThread::run()`方法来启动新的线程。这会创建一个新的线程,并在其运行你的任务。你可以使用这个新的线程来执行任何你需要的操作,包括再次创建新的线程。需要注意的是,由于QT的线程模型是分层的,因此你需要小心避免创建过多的线程,以防止出现死锁或其他并发问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值