Linux中线程的基本概念与线程控制

Linux操作系统中线程

1、进程指的是加载进内存的程序,进程 = 内核数据结构 + 进程代码和数据

2、进程在执行ABCD四个函数时是一个单执行流,而如果想让AB函数和CD函数并发执行**,我们通常会创建一个子进程,但这意味着需要创建新的进程控制块、进程地址空间、页表,极大的浪费了虚拟地址*****(地址空间)***

**3、Linux为了解决上述的资源浪费问题,规定在创建子进程时只复制其父进程的PCB,并与其它子进程一起共享父进程的进程地址空间以及页表等内容,同时将代码区中的代码进行分块,保证每个子进程的PCB只能看见为其分配好的代码块,这就是****Linux操作系统中多线程的实现方式,****因为这种独特的实现方式,**所以Linux操作系统中的线程也叫做轻量级进程

4、因为一个进程在执行其代码块中的内容时被看作是一个执行流,所以一个线程***(轻量级进程)也可以被视为一个执行流(完整的执行流需要PCB、进程地址空间、页表、代码和数据,这些内容线程都有只不过可能是借用了进程的部分内容,并且还对代码块做了限制让每个线程看到的函数都不一样,每个线程都会去执行被分配好的代码块中的内容)* 因此一个进程中会有至少一个执行流,综上所述:** 线程 <= 执行流 <= 进程

5、在Linux的中讨论多线程就是讨论一个进程中到底有几个执行流,即在Linux中线程就是进程中的执行流***(而不是Windows或者理论中的那样,完完全全是不同的两个内容)***

6、Linux中的多线程与理论上的多线程的实现方式不同***(Windows中的线程设计是符合理论的),是因为Linux的设计者认为设计线程就要设计线程控制块(新的数据结构TCB)以及与线程相关的调度算法,但进程和线程实际上具有很高的相似性(上图所示)***,没必要单独设计数据结构和调度算法

**结论:**在Linux操作系统中,CPU在调度PCB时不关心该PCB是进程的还是线程的只负责调度,因为在CPU看来它们都是不同执行流中的PCB,故可以说进程是系统分配资源的基本单位,而线程是进程内部的一个执行分支,是CPU调度的基本单位

pthread_create函数

#include <pthread.h>

int _create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine) (void *), void *arg);

多执行流代码划分

基本概念:大部分操作系统每次都是以4KB大小为基本单位(或4*n大小)对内存进行管理的,磁盘中的数据加载到内存时也是以4KB大小为基本单位,我们叫

线程的理解

页表与页框

线程控制

~over~

相关推荐
guozhetao1 分钟前
【ST表、倍增】P7167 [eJOI 2020] Fountain (Day1)
java·c++·python·算法·leetcode·深度优先·图论
技术思考者1 分钟前
基础很薄弱如何规划考研
java·经验分享·考研
●VON25 分钟前
重生之我在暑假学习微服务第二天《MybatisPlus-下篇》
java·学习·微服务·架构·mybatis-plus
老华带你飞25 分钟前
口腔助手|口腔挂号预约小程序|基于微信小程序的口腔门诊预约系统的设计与实现(源码+数据库+文档)
java·数据库·微信小程序·小程序·论文·毕设·口腔小程序
枫叶丹427 分钟前
【Qt开发】信号与槽(二)-> 信号和槽的使用
开发语言·qt
hqxstudying35 分钟前
J2EE模式---服务层模式
java·数据库·后端·spring·oracle·java-ee
GM_82840 分钟前
【最新最完整】SpringAI-1.0.0开发MCP Server,搭建MCP Client 实战笔记(进阶+详细+完整代码)
java·后端·ai编程·springai·mcp
都叫我大帅哥42 分钟前
Java DelayQueue:时间管理大师的终极武器
java
秋千码途1 小时前
小架构step系列27:Hibernate提供的validator
java·spring·架构·hibernate
都叫我大帅哥1 小时前
TOGAF迁移规划阶段全解密:从菜鸟到达人的通关秘籍
java