服务器之家:专注于服务器技术及软件下载分享
分类导航

Linux|Centos|Ubuntu|系统进程|Fedora|注册表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服务器之家 - 服务器系统 - Linux - Linux线程退出方式总结(推荐)

Linux线程退出方式总结(推荐)

2021-12-20 16:44Linux教程网 Linux

下面小编就为大家带来一篇Linux线程退出方式总结(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

在编写多线程代码时,经常面临线程安全退出的问题。

一般情况下,选择检查标志位的方式:

在线程的while循环中,执行完例程后,都对标志位进行检查,如果标志位指示继续执行则再次执行例程,如果标志位设置为退出状态,则跳出循环,结束线程的运行。

这个标志位需要主线程(或其他线程)设置,设置后,主线程调用pthread_join接口进入休眠(接口参数指定了等待的线程控制指针),子线程退出后,主线程会接收到系统的信号,从休眠中恢复,这个时候就可以去做相关的资源清除动作。

这个方法可以保证子线程完全退出,主线程再去做相关的资源清除操作

时序图如下

Linux线程退出方式总结(推荐)

但是某些应用中,或许会发生下面情况:

子线程阻塞在某个操作无法被唤醒,即使主线程设置了标志位,由于子线程进入了休眠无法醒过来,也没有办法去检查标志位,这个时候调用pthread_join进入休眠的主线程等待不到子线程退出的信号,也会一直休眠,系统进入死锁。

为了更安全地使线程退出,主线程通过pthread_cancel函数来请求取消同一进程中的其他线程,再调用pthread_join等待指定线程退出。使用pthread_cancel接口,需要了解linux下线程的两个属性,可取消状态和可取消类型,以及取消点的概念。

可取消状态:包括pthread_cancel_enable和pthread_cancel_disable。当线程处于pthread_cancel_enable,收到cancel请求会使该线程退出运行;反之,若处于pthread_cancel_disable,收到的cancel请求将处于未决状态,线程不会退出。线程启动时的默认可取消状态为pthread_cancel_enable,可以通过接口pthread_setcancelstate改变可取消状态的属性。

可取消类型:包括pthread_cancel_deferred和pthread_cancel_asynchronous。当处于pthread_cancel_deferred,线程在收到cancel请求后,需要运行到取消点才能退出运行;如果处于pthread_cancel_asynchronous,可以在任意时间取消,只要收到cancel请求即可马上退出。线程启动时默认可取消类型为pthread_cancel_deferred,可通过pthread_setcanceltype修改可取消类型。

取消点:线程检查是否被取消并按照请求进行动作的一个位置。

采用pthread_cancel_deferred取消方式是因为线程可能在获取临界资源后(如获取锁),未释放资源前收到退出信号,如果使用pthread_cancel_ asynchronous的方式,无论线程运行到哪个位置,都会马上退出,而占有的资源却得不到释放。

采用pthread_cancel_deferred取消方式,线程需要运行到取消点才退出,而主线程在调用pthread_cancel后,不能马上进行线程资源释放,必须调用pthread_join进入休眠,直至等待指定线程退出。

使用pthread_cancel_deferred方式并不能完全避免这个问题,因为无法保证在获取临界资源后(比如lock操作)不会进行可以作为取消点的操作(如进行sleep),此时主线程如果对该线程发送cancel信号,线程将会在不释放锁的情况下直接结束运行,即还是会出现在释放资源前线程就退出的问题。

为了避免上述情况,不仅需要设置可取消类型,还需要设置可取消状态。将获取临界资源-释放临界资源之间的代码块都设置成pthread_cancel_disable状态,其余的代码块都设置成pthread_cancel_enable状态,确保线程在安全的地方退出。如果在可以安全退出的代码块不存在取消点系统调用,可以调用pthread_testcancel函数自己添加取消点。

伪代码描述如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
void* subthread(void*)
{
  pthread_setcancelstate(pthread_cancel_enable,&oldcanclestate);
  …;//不存在获取临界资源操作,可以安全退出的代码块
  pthread_testcancel();//如果可以安全退出的代码块不存在取消点操作,可以自己添加pthread_testcancel调用,线程执行到这个调用就会退出
  /*还有一种方法,在可以安全退出的代码块,我们将线程的可取消类型设置成pthread_cancel_ asynchronous,这样即使没有取消点也可以马上退出*/
 
  pthread_setcancelstate(pthread_cancel_disable,&oldcanclestate);
  /*存在获取-释放临界资源操作,如果在lock和unlock之间的运行收到cancel信号,且可取消状态为enable,则锁永远无法被释放*/
  lock();
  …;
  unlock();
}
 
void* mainthread(void*)
{
  pthread_cancel(subthread);//给subthread发送退出信号
  pthread_join(subthread,null);//进入休眠,直到subthread退出成功
}

无论使用哪种方式,核心点就是要保证线程退出的时候不会获取了某些临界资源而无法释放

posix.1定义的取消点见下:
Linux线程退出方式总结(推荐)
Linux线程退出方式总结(推荐)

注意:当主线程调用pthread_cancel接口后,只是将取消请求发送给指定线程,
对接口的成功调用不能保证指定线程已经退出,需要调用pthread_join等待指定线程完全退出,再进行相关资源的释放。

以上就是小编为大家带来的linux线程退出方式总结(推荐)全部内容了,希望大家多多支持服务器之家~

延伸 · 阅读

精彩推荐
  • LinuxLinux lnmp下无法使用mail发邮件的两种解决方法

    Linux lnmp下无法使用mail发邮件的两种解决方法

    在配置了lnmp环境后,出现了mail函数不能发送邮件的问题,其实有两种方法,一是使用sendmail组件,而是使用postfix。下面为大家一一介绍下 ...

    Linux之家4042019-09-17
  • Linux确保Linux系统安全的前提条件 漏洞防护

    确保Linux系统安全的前提条件 漏洞防护

    Linux 作为开放式的操作系统受到很多程序员的喜爱,很多高级程序员都喜欢编写Linux操作系统的相关软件。这使得Linux操作系统有着丰富的软件支持,还有无...

    Linux之家2642020-04-11
  • Linux手把手教您在 Linux 上使用 GPG 加解密文件

    手把手教您在 Linux 上使用 GPG 加解密文件

    在本教程中,我将告诉你如何用 GPG 加密和解密文件。这是一个简单的教程,你可以在你的 Linux 系统上尝试所有的练习。这将帮助你练习 GPG 命令,并在你...

    Linux中国6962021-12-15
  • Linuxlinux中rmdir命令使用详解(删除空目录)

    linux中rmdir命令使用详解(删除空目录)

    今天学习一下linux中命令: rmdir命令。rmdir是常用的命令,该命令的功能是删除空目录,一个目录被删除之前必须是空的 ...

    linux命令大全5372019-11-19
  • Linux详解Linux系统下PXE服务器的部署过程

    详解Linux系统下PXE服务器的部署过程

    这篇文章主要介绍了Linux系统下PXE服务器的部署过程,包括对PXE的API架构作了一个基本的简介,需要的朋友可以参考下...

    运维之道9812019-07-04
  • LinuxLinux上设置用户通过SFTP访问目录的权限的方法

    Linux上设置用户通过SFTP访问目录的权限的方法

    这篇文章主要介绍了Linux上设置用户通过SFTP访问目录的权限的方法,SFTP可以理解为使用SSH协议进行FTP传输的协议,因而同时要对OpenSSH进行相关设置,需要的朋...

    OSChina10022019-06-19
  • LinuxLinux中环境变量配置的步骤详解

    Linux中环境变量配置的步骤详解

    Linux中环境变量包括系统级和用户级,系统级的环境变量是每个登录到系统的用户都要读取的系统变量,而用户级的环境变量则是该用户使用系统时加载的...

    Myths7882022-02-10
  • LinuxLinux常用的日志文件和常用命令

    Linux常用的日志文件和常用命令

    成功地管理任何系统的关键之一,是要知道系统中正在发生什么事。 Linux 中提供了异常日志,并且日志的细节是可配置的。Linux 日志都以明文形式存储,所...

    Linux教程网2632020-04-18