多线程并发的特征有哪些

发布时间:2021-10-25 09:21:18 作者:iii
来源:亿速云 阅读:195

本篇内容主要讲解“多线程并发的特征有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“多线程并发的特征有哪些”吧!

多线程和并发

在使用C++开发的服务端程序中多线程还是主流,一般来说会有个线程池来处理接收的请求,这样可以有效提供服务器的并发能力和CPU的利用率。

多线程并发的特征有哪些

但是,多线程也是一把双刃剑。

单线程模式下,一切都是那么单调而稳定,所有的资源都是自己的,我的资源我做主。

多线程模式下,一个进程下装载了多个线程,每个线程除了部分资源是独享外,多个线程对大部分系统资源是共享的。

多个线程共享的进程资源:

每个线程独享的资源:

多线程并发的特征有哪些

敲黑板划重点:

1.进程是系统进行资源分配和调度的基本单位,线程是CPU调度和分派的基本单位;

2.进程是线程的载体,进程有独立地址空间,所有线程共享所在进程的地址空间;

3.进程是系统资源的大股东,而线程基本上不拥有系统资源,只占用少量在运行中必不可少的资源,比如程序计数器、一组寄存器和调用栈;

同一个进程中的多个线程有点像合租,大家共用大部分资源,自己独占一小部分资源,相互影响,然而但单进程单线程就是整租,自己独占所有资源,谁也不影响。

多线程并发的特征有哪些

掌握多线程中资源共享和相互影响的特点之后,再来看看线程安全和可重入就容易很多。

多线程并发的特征有哪些

什么是线程安全

计算机中所谓的安全大多是指结果的正确且可预测性。

前面我们知道,多线程运行起来虽然可以提高并发能力,但是多个线程会共享很多资源,比如写全局数据,这种情况下就需要额外干预,否则将引发错乱的结果。

线程安全是在拥有共享数据的多条线程并行执行的进程中,可以正常且正确的执行,不会出现数据污染等意外情况,反之则称为线程不安全。

通俗一点讲,线程安全就怎么跑都不乱,线程不安全就是一跑就可能五花八门。

所以可能产生线程不安全根本原因在于:共享数据且共享数据可变。

这些共享数据包括全局变量、局部静态变量等,每个线程都可能对这个数据进行操作,并且操作结果会影响其他线程。

我们还经常提到另外一个术语:线程安全函数/线程安全类。

线程安全函数的一些特征:

多线程并发的特征有哪些

从图中可以看到:

在编写多线程程序时,如果涉及多个线程操作一个公共函数,如果该函数本身不是线程安全的。

例如当一个函数F是线程安全函数,但是F调用线程不安全函数G时,同样需要对G进行加锁处理,否则函数F也将不安全。

在《深入理解计算机系统》一书中深入指出了线程不安全函数的分类:

前面介绍的几个例子大部分都是全局变量的不加锁控制相关的,还有两种就是:

// 函数原型 struct tm * localtime(const time_t *clock);  /* localtime example */ #include <stdio.h>  #include <time.h>   int main () {   time_t rawtime;   struct tm * timeinfo;    time (&rawtime);   timeinfo = localtime (&rawtime);    return 0; }

在localtime中将结果存放在timeinfo中,这个全局变量可以被任意的线程操作,因此将引发线程不安全。

对于Linux中线程不安全的函数可以查阅:

https://man7.org/linux/man-pages/man7/pthreads.7.html

可重入函数

在理解了线程安全的相关定义和形成原因之后,我们来看下什么是可重入。

先来看看可重入的相关定义:

一个程序可以在任意时刻被中断,然后系统去执行另外一段代码,结束后又调用继续原来的子程序不会出错,则称其为可重入(reentrant或re-entrant)。

从根本上来说:

可重入函数又分为两大类:

可重入函数需要满足以下几个条件:

从本质上来说,可重入函数实现了算法和数据的分离,函数内部的计算不依赖于外部,不影响也不受外部影响,是一种高效且安全的函数。

可重入函数都是线程安全函数,线程安全不一定是可重入函数。

多线程并发的特征有哪些

不可重入函数可以遵守可重入规则去改造,从而变为可重入函数。

到此,相信大家对“多线程并发的特征有哪些”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

推荐阅读:
  1. IINA有哪些特征
  2. 云计算的有哪些特征

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:如何实现清除Mysql数据库的特定表无用数据的存储过程

下一篇:Python爬虫经常会被封的原因是什么

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》