Linux并发程序设计(5):线程的相关操作
目录
进程与线程的对比
1、地址
2、开销
3、并发性
一、线程创建
二、线程结束
三、线程查看tid
四、线程回收
五、线程分离
1、使用pthread_detach
2、在创建线程时指定分离属性
六、取消线程
七、清理线程
进程与线程的对比
1、地址
- 进程是资源分配的最小单位,线程是CPU调度的最小单位,进程有独立分配的内存空间,线程共享进程空间;
- 真正在CPU上运行的是线程。
2、开销
- 进程切换开销大,线程轻量级
3、并发性
- 进程并发性差
一、线程创建
#include <pthread.h>
int pthread_create(pthread_t* thread,const pthread_attr_t* attr,void*(*routine)(void*),void* arg);
- 成功返回0,失败返回错误码
- thread 线程对象
- attr 线程属性,NULL代表默认属性
- routine 线程执行的函数
- arg 传递给routine的参数,参数是void*,注意传递参数格式
注意:
1、主线程的退出,它创建的线程也会退出;
2、创建线程需要时间,如果主线程马上退出,那线程不能得到执行
二、线程结束
#include <pthread.h>
void pthread_exit(void* retval);
- 结束当前线程
- retval可被其他线程通过pthread_join获取
- 线程私有资源被释放
三、线程查看tid
通过在线程里调用pthread_self函数。
#include <pthread.h>
pthread_t pthread_self(void);
四、线程回收
#include <pthread.h>
int pthread_join(pthread_t thread,void** retval);
对于一个默认属性的线程来说,线程占用的资源并不会因为执行结束而得到释放。
成功返回0,失败返回错误码
thread--要回收的线程对象
调用线程阻塞直到thread结束
*retval 接收线程thread的返回值
五、线程分离
1、使用pthread_detach
#include <pthread.h>
int pthread_detach(pthread_t thread);
指定该线程状态,线程主动与主线程断开,线程结束后不会产生僵尸线程。
2、在创建线程时指定分离属性
- 通过线程属性设置分离态
pthread_attr_t attr; /*通过线程属性来设置游离态(分离态)*/
- 设置线程属性为分类
pthread_attr_init(&attr);
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
六、取消线程
int pthread_cancel(pthread_t thread);
七、清理线程
void pthread_cleanup_push(void (*routine) (void *), void *arg);
功能:该函数用于注册一个清理处理程序。当线程遇到以下三种情况之一时,会调用这个清理处理程序:
- 线程被取消(通过
pthread_cancel
函数)。 - 线程调用
pthread_exit
函数退出。 - 线程从
pthread_cleanup_pop
函数以非零参数调用返回。
参数:
void (*routine) (void *)
:这是一个函数指针,指向清理处理程序。该函数接受一个void *
类型的参数,并且返回值为void
。void *arg
:传递给清理处理程序的参数
void pthread_cleanup_pop(int execute);
功能:该函数用于移除最近一次由 pthread_cleanup_push
注册的清理处理程序。根据传入的参数 execute
的值,决定是否执行这个清理处理程序。
参数:
int execute
:如果该参数的值为非零,则执行清理处理程序;如果为零,则不执行清理处理程序,直接移除该清理处理程序。