【Linux学习】pthread_create主线程与创建的新线程之间退出关系

我们在一个线程中经常会创建另外的新线程,如果主线程退出,会不会影响它所创建的新线程呢?下面就来讨论一下。

 

1、  主线程等待新线程先结束退出,主线程后退出。正常执行。

实例代码:

#include "apue.h"
#include <pthread.h>

pthread_t ntid;//线程ID

void printids(const char *s)
{
        pid_t pid;
        pthread_t tid;
        pid = getpid();
        tid = pthread_self();
        printf("%s pid %u tid %u (0x%x)\n",s,(unsigned int)pid,
                        (unsigned int)tid,(unsigned int)tid);
}

void *thrfun(void *arg){
        //sleep(1);//使得主线程先退出
        printids("new thread");

        return ((void *)0);
}

int main(){
        int err;
        err = pthread_create(&ntid,NULL,thrfun,NULL);

        if(err != 0)
                err_quit("can't create thread: %s\n",strerror(err));
        printids("main thread");

        sleep(1);//等待新线程先结束

        exit(0);
}
运行结果:


2、  进程先退出,新线程也会立即退出,系统清除所有资源。

实例代码:

#include "apue.h"
#include <pthread.h>

pthread_t ntid;//线程ID

void printids(const char *s)
{
        pid_t pid;
        pthread_t tid;
        pid = getpid();
        tid = pthread_self();
        printf("%s pid %u tid %u (0x%x)\n",s,(unsigned int)pid,
                        (unsigned int)tid,(unsigned int)tid);
}

void *thrfun(void *arg){
        sleep(1);//使得主线程先退出
        printids("new thread");

        return ((void *)0);
}

int main(){
        int err;
        err = pthread_create(&ntid,NULL,thrfun,NULL);

        if(err != 0)
                err_quit("can't create thread: %s\n",strerror(err));
        printids("main thread");

        //sleep(1);

        exit(0);//注意是进程(不是线程)退出
}

运行结果:


可以发现主线程退出后所创建的新线程也停止运行了。


3、如果主线程调用了pthread_exit,那么它退出了,子线程也不会退出。

实例代码:

#include "apue.h"
#include <pthread.h>

pthread_t ntid;//线程ID

void printids(const char *s)
{
        pid_t pid;
        pthread_t tid;
        pid = getpid();
        tid = pthread_self();
        printf("%s pid %u tid %u (0x%x)\n",s,(unsigned int)pid,
                        (unsigned int)tid,(unsigned int)tid);
}

void *thrfun(void *arg){
        sleep(1);//使得主线程先退出
        printids("new thread");

        return ((void *)0);
}

int main(){
        int err;
        err = pthread_create(&ntid,NULL,thrfun,NULL);

        if(err != 0)
                err_quit("can't create thread: %s\n",strerror(err));
        printids("main thread");

        //sleep(1);

            pthread_exit(NULL);

        exit(0);
}
运行结果:



POSIX标准定义:

When you program with POSIX Threads API,there is one thing about pthread_exit() that you may ignore for mistake. Insubroutines that complete normally, there is nothing special you have to dounless you want to pass a return code back using pthread_exit(). The completionwon't affect the other threads which were created by the main thread of thissubroutine. However, in main(), when the code has been executed to the end,there could leave a choice for you. If you want to kill all the threads thatmain() created before, you can dispense with calling any functions. But if you want to keep the process and all the other threadsexcept for the main thread alive after the exit of main(), then you can call pthread_exit()to realize it. And any files opened inside the main thread will remain openafter its termination.

 

按照POSIX标准定义,当主线程在子线程终止之前调用pthread_exit()时,子线程是不会退出的。

 

注意:这里在main函数中调用pthread_exit()只会是主线程退出,而进程并未退出。因此新线程继续执行而没有退出。

我们可以在return 0;这条语句前面添加一条输出语句printf(“Mainthread has exited!\n”);来进行测试,输出结果不发生任何变化,说明这条语句没有被执行到。也就说明进程并未退出。

 

因此:

一个线程的退出不会影响另外一个线程。但是进程结束,所有线程也就结束了,所有资源会被回收。

 

我们可以再写一个程序来进行验证:

4、在创建的新线程B中再次创建新线程C,那么如果B先退出,那么C将会继续执行而不会退出。

实例代码:

#include "apue.h"
#include<pthread.h>

pthread_t ntid;//线程ID

void printids(const char *s)
{
        pid_t pid;
        pthread_t tid;
        pid = getpid();
        tid = pthread_self();
        printf("%s pid %u tid %u (0x%x)\n",s,(unsigned int)pid,
                       (unsigned int)tid,(unsigned int)tid);
}


void *thrfun2(void *arg){
        sleep(1);//使得创建它的主线程先退出
        printids("new thread of the new thread");

        return ((void *)0);
}

void *thrfun(void *arg){
        sleep(1);//使得主线程先退出
        printids("new thread");
        int err;
        err = pthread_create(&ntid,NULL,thrfun2,NULL);

        if(err != 0)
                err_quit("can'tcreate thread: %s\n",strerror(err));

        return ((void *)0);
}

int main(){
        int err;
        err = pthread_create(&ntid,NULL,thrfun,NULL);

        if(err != 0)
                err_quit("can'tcreate thread: %s\n",strerror(err));
        printids("main thread");

        //sleep(1);

        pthread_exit(NULL);

        printf("main thread has exited!\n");

        exit(0);
}

运行结果:






  • 10
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
通过pthread_create和pthread_exit调用参数与线程T2交换数据的方法如下: 1. 首先,在线程创建线程T2和线程T1,通过pthread_create函数传递参数给线程T2。例如,可以通过定义一个结构体来传递需要交换的数据,然后将该结构体指针作为参数传递给pthread_create函数。 2. 在线程T2中,通过解引用参数指针来获取到传递的数据。可以使用类型转换将void类型的参数指针转换为所需的类型,然后再进行解引用操作。 3. 在线程T2中,通过修改数据来与线程T1交换数据。可以通过指针操作来修改数据内容。 4. 线程T2执行完毕后,可以通过pthread_exit函数退出线程,并将需要传递给线程的数据作为参数传递给pthread_exit函数。 5. 在线程中,可以通过pthread_join函数获取线程T2的退出状态,并通过解引用参数指针来获取到传递给pthread_exit函数的数据。 总结起来,通过pthread_create函数传递参数给线程T2,线程T2通过解引用参数指针获取到传递的数据,并通过修改数据来与线程T1交换数据。线程T2执行完毕后,通过pthread_exit函数退出线程,并将需要传递给线程的数据作为参数传递给pthread_exit函数。在线程中,可以通过pthread_join函数获取线程T2的退出状态,并通过解引用参数指针来获取到传递给pthread_exit函数的数据。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Linux线程(2)——创建、终止和回收(pthread_create()、pthread_exit()、pthread_join())](https://blog.csdn.net/cj_lsk/article/details/130229709)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Linux多线程编程(pthread_creat、pthread_exit、pthread_join、pthread_detach)](https://blog.csdn.net/weixin_42934918/article/details/114363789)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

没有昵称阿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值