Pthread线程使用详解

简介: 文中先讲解函数,再运行实例,以及一些注意事项

文中先讲解函数,再运行实例,以及一些注意事项。


一、使用pthread创建一个子线程并传入参数


函数pthread_create,使用man 3 pthread_create查看介绍。


1.1 函数基本用法讲解


1.1.1 pthread_create

#include <pthread.h>
/*在当前进程中创建一个新的线程,新线程的运行会调用start_routine函数,同时传递arg参数给
*start_routine函数
*/
int pthread_create(pthread_t *thread, //新线程句柄
                              const pthread_attr_t *attr,//新线程的属性
                              void *(*start_routine) (void *), //新线程调用的函数
                              void *arg);//传递给新线程的参数

函数描述:

通过pthread_create创建的新线程,有收下四种方法退出线程:

  1. 调用pthread_exit(value),value是退出状态值,该值对同进程中调用了pthread_join()的线程是可见的;
  2. start_routine返回,在该函数中调用return语句
  3. 线程被cancel,参见pthread_cancel()
  4. 任何线程调用了exit方法,或者主线程在main函数中返回,都会导致所有线程的退出。

attr参数是一个pthread_attr_t结构体,它在线程被创建时被用来设定新线程的属性。这个结构体的初始化是通过pthread_attr_init()函数。如果该参数为空,那么新线程会使用默认的属性参数。

pthread_create函数调用返回之前,新线程的内存指针会赋给thread参数,表示线程的ID,这个ID的作用是在后续可以调用针对该线程的其它pthreads函数。

返回值

成功返回0,失败返回一个错误编号,同时thread参数也不会被赋值。

pthread_join

函数描述

#include <pthread.h>
int pthread_join(pthread_t thread, void **retval);

pthread_join函数会等待指定的线程结束,如果指定的线程已经线束,那么它会立即返回。指定的线程必须是joinable的。也就是说,pthread_join()函数会一直阻塞调用线程,直到指定的线程tid终止。当pthread_join()返回之后,应用程序可回收与已终止线程关联的任何数据存储空间,(另外也可设置线程attr属性,当线程结束时直接回收资源)如果没有必要等待特定的线程终止之后才进行其他处理,则应当将该线程分离pthread_detach()

如果retval不为空,那么该函数会拷贝退出状态值到retval指向的内存中,如果目标thread被cancel了,retval的值为PTHREAD_CANCELED

返回值

成功返回0,错误返回错误码

目录
相关文章
|
23天前
|
安全 程序员 API
|
3月前
|
存储 安全 Unix
并发编程基础:使用POSIX线程(pthread)进行多线程编程。
并发编程基础:使用POSIX线程(pthread)进行多线程编程。
90 0
|
Linux
Linux系统编程-(pthread)线程通信(自旋锁)
自旋锁不管是内核编程,还是应用层编程都会用到;自旋锁和互斥量类似,它不是通过休眠使进程阻塞,而是在获取锁之前一直处于忙等(也就叫自旋)状态。
422 1
|
监控 Linux
Linux系统编程-(pthread)线程通信(条件变量)
条件变量是线程可用的一种同步机制,条件变量给多个线程提供了一个回合的场所,条件变量和互斥量一起使用,允许线程以无竞争的方式等待特定的条件发生。 条件变量本身是由互斥体保护的,线程在改变条件状态之前必须首先锁住互斥量,其他线程在获取互斥量之前就不会觉察到这种变化,因为互斥量必须锁定之后才改变条件。
189 0
|
Linux
Linux系统编程-(pthread)线程通信(读写锁)
**读写锁与互斥锁类似,读写锁比互斥锁有更高的并行性,读写锁特点如下:** ​ 1. 读写锁有三种状态,读模式下加锁(共享)、写模式下加锁(独占)以及不加锁。 ​ 2. 一次只有一个线程可以占有写模式下的读写锁;但是多个线程可以同时占有读模式下的读写锁。 ​ 3. 读写锁在写加锁状态时,其他试图以写状态加锁的线程都会被阻塞。读写锁在读加锁状态时,如果有线程希望以写模式加锁时,必须阻塞,直到所有线程释放锁。 ​ 4. 当读写锁以读模式加锁时,如果有线程试图以写模式对其加锁,那么读写锁会阻塞随后的读模式锁请求,以避免读锁长期占用,而写锁得不到请求。
227 0
|
Linux API
Linux系统编程-(pthread)线程通信(信号量)
信号量的运用环境与互斥锁一样,但是信号量比互斥锁增加灵活,互斥锁只有两个状态(开锁和解锁),而信号量本质上是一个计数器,它内部有一个变量计数信号值,可以保护一个资源可以同时被1个或者2个或者3个线程同时使用,如果信号量的值只是设置1(状态只有0和1),那么和互斥锁就是一样的功能。
627 0
|
Linux
Linux系统编程-(pthread)线程通信(围栏机制)
Linux线程里还支持一个围栏机制--也就是屏障功能。这个围栏机制,可以设置等待的线程数量,当指定数量的线程都到齐之后再全部唤醒—放行。它的的功能和它的名字是匹配的,就是围栏,就像在赛跑比赛场上,要进行比赛时,必须等待所有运动员都到齐全了,都到起跑线上了,然后一声令下,大家再一起跑出去。
375 0
|
Linux
Linux系统编程-(pthread)线程通信(互斥锁)
这篇文章介绍Linux下线程同步与互斥机制--互斥锁,在多线程并发的时候,都会出现多个消费者取数据的情况,这种时候数据都需要进行保护,比如: 火车票售票系统、汽车票售票系统一样,总票数是固定的,但是购票的终端非常多。
450 0
|
Linux
Linux系统编程-(pthread)线程的使用案例(分离属性、清理函数等)
这篇文章介绍Linux下线程的创建与基本使用案例,主要是案例代码为主;相关的函数详细介绍在上篇文章里已经介绍过了。
215 0
|
1月前
|
存储 消息中间件 资源调度
C++ 多线程之初识多线程
这篇文章介绍了C++多线程的基本概念,包括进程和线程的定义、并发的实现方式,以及如何在C++中创建和管理线程,包括使用`std::thread`库、线程的join和detach方法,并通过示例代码展示了如何创建和使用多线程。
48 1
C++ 多线程之初识多线程
下一篇
无影云桌面