您现在的位置是:首页 > 正文

进程互斥与同步计算机操作系统_操作系统心得体会

2024-01-30 22:04:07阅读 0

一、操作系统

1.基本概念

操作系统简称OS,是配置在计算机硬件上的第一层软件,它能够有效的组织和管理计算机系统中的硬件和软件资源,合理的组织计算机工作流程,控制程序的执行,并向用户提供各种服务功能。OS是现代计算机系统中最基本和最重要的系统软件。

2.操作系统的作用

它有三个作用:第一,OS作为用户与计算机硬件系统之间的接口;第二,OS作为计算机系统资源的管理者;第三,OS实现了对计算机资源的抽象。

3.操作系统的主要特征

操作系统的主要特征是:并发,共享,虚拟和异步,这四个特征之间也有紧密的联系。

(1)并发和共享是操作系统的最基本特征

(2)并发和共享互为存在条件

(3)虚拟以并发和共享为前提条件

(4)异步是并发和共享的必然结果

4.操作系统的主要功能

操作系统的主要功能是:处理机功能,存储器功能,设备管理和文件管理等基本功能。

二、进程与线程

1.进程

进程是操作系统进行资源分配的基本单位。进程控制块 (PCB) 描述进程的基本信息和运行状态,所谓的创建进程和撤销进程,都是指对 PCB 的操作。

进程具有三种状态:就绪,阻塞和执行

cbdaebd7401982d519669d5c7ca88425.png

2. 线程

一个线程中可以有多个线程,是独立调度和分派的基本单位。同一个进程中的多个线程之间可以并发执行,它们共享进程资源。

3. 调度算法

(1)批处理系统中的调度:先来先服务(FCFS),短作业优先(SJF),最短时间剩余优先(SRTN)

(2)交互式系统中的调度:优先权优先,时间片轮转,多级反馈队列,短进程优先

(3)实时系统中的调度:硬实时和软实时

4. 进程同步

(1)同步与互斥

同步指多个进程按一定顺序执行;互斥指多个进程在同一时刻只有一个进程能进入临界区。

同步是在对临界区互斥访问的基础上,通过其它机制来实现有序访问的

(2)信号量

如果信号量的取值只能为 0 或者 1,那么就成为了互斥量(Mutex),0 表示临界区已经加锁,1 表示临界区解锁。

typedef int samaphore;

samaphore mutex = 1;

void PA() {

While(1){

wait(mutex);

// 临界区

signal(mutex);

//剩余区

}

}

void PB() {

While(1){

wait(mutex);

// 临界区

signal(mutex);

//剩余区

}

}

(3)经典进程同步问题

1.使用信号量实现生产者-消费者问题:

假定在生产者和消费者之间的公共缓冲池中具有n个缓冲区,使用一个互斥量 mutex 来对临界资源进行访问;empty 记录空缓冲区的数量,full 记录满缓冲区的数量。

如果将该问题用卖衣服形容,大致过程如下:

商家生产衣服(生产者制造数据)->商家把生产好的衣服放到店里卖(生产者把数据放入缓冲区)->顾客买衣服(消费者从缓冲区取出数据)->顾客拿回去进行裁剪之类的动作(消费者处理数据)

2.读者-写者问题

允许多个进程同时对数据进行读操作,但是不允许读和写以及写和写操作同时发生。

一个整型变量 count 记录在对数据进行读操作的进程数量,一个互斥量 count_mutex 用于对 count 加锁,一个互斥量 data_mutex 用于对读写的数据加锁。

3.哲学家进餐问题

五个哲学家围着一张圆周,每个哲学家面前放着饭。哲学家的生活有两种交替活动:吃饭以及思考。当一个哲学家吃饭时,需要先一根一根拿起左右两边的筷子。为了防止死锁的发生,可以加一点限制,只允许同时拿起左右两边的筷子,方法是引入一个互斥量,对拿起两个筷子的那段代码加锁。

三、死锁

集合中的每一个进程都在等待只能由本集合中的其他进程才能引发的事件,那么该组进程是死锁的。

1. 死锁产生的必要条件

互斥条件,请求和保持条件,不可抢占条件,循环等待条件

2. 死锁的处理方法

(1)预防死锁

破坏不可抢占条件、破坏请求和保持条件、破坏循环(环路)等待条件

注:不可破坏互斥条件,因为互斥条件是非共享设备所必须的。

(2)避免死锁

利用银行家算法避免死锁:

可利用资源向量Available,最大需求矩阵Max,分配矩阵Alloc,需求矩阵Need。

67aa5bb2091ca95d68f041628f2ce23a.png

(3)死锁检测与解除

四、存储器管理

1. 分页和分段

(1) 分页

用户程序的地址空间被划分为若干固定大小的区域,称为“页”。相应地,内存空间分成若干个物理块,页和块的大小相等,页与块的对应关系称为“页表”。可将用户程序的任一页放在内存的任一块中,实现了离散分配,由一个页表来维护它们之间的映射关系。

(2)分段

分段的做法是把每个表分成段,一个段构成一个独立的地址空间。每个段的长度可以不同,可以动态改变。

每个段都需要程序员来划分。

(3)段页式

用分段方法来分配和管理虚拟存储器。程序的地址空间按逻辑单位分成基本独立的段,而每一段有自己的段名,再把每段分成固定大小的若干页。

用分页方法来分配和管理实存。即把整个主存分成与上述页大小相等的存储块,可装入作业的任何一页。程序对内存的调入或调出是按页进行的。但它又可按段实现共享和保护。

(4)分页与分段区别

地址空间的维度:分页是一维地址空间,分段是二维的。

大小是否可以改变:页的大小不可变,段的大小可以动态改变。

对程序员的透明性:分页透明,但是分段需要程序员显示划分每个段。

2. 存储管理

(1)分页式存储管理

需要访问两次内存,目的是提高内存利用率

物理地址=页的大小页号+页内位移

页号=相对地址/块尺寸

页内位移=相对地址%块尺寸

(2)分段式存储管理

目的:方便用户使用编程,存储共享,存储保护,动态增长, 动态链接

段表:段号、段长、该段在内存的基址(起始地址) {段号,段内位移}

物理地址=段的起始地址+段内地址

逻辑地址=段号+段内地址

(3)分段式存储管理(三次访问内存)

基本原理:万段和力页原理的结合,即先将用户程序力成若干个段,再把每个段分成若干个页,并为每一个段赋予一个段名。

逻辑地址= 段号+页号+页内位置

虚拟存储器:是具有请求调入功能和置换功能,能从逻辑上对内存容里加以扩充的一种存储器系统,其逻辑容里由内存容里和外存容里之和所决定,其运行速度接近于内存速度。

3. 页面置换算法

(1) 最佳(Optimal)

所选择的被换出的页面将是最长时间内不再被访问,通常可以保证获得最低的缺页率。

举例:一个系统为某进程分配了三个物理块,并有如下页面引用序列:

7,0,1,2,0,3,0,4,2,3,0,3,2,1,2,0,1,7,0,1

进程运行时,先将 7,0,1 三个页面装入内存。当进程要访问页面 2 时,产生缺页中断,会将页面 7 换出,因为页面 7 再次被访问的时间最长。

(2)先进先出(FIFO)

所选择换出的页面是最先进入的页面。

该算法会将那些经常被访问的页面也被换出,从而使缺页率升高。

(3)最近最久未使用(LRU, Least Recently Used)

虽然无法知道将来要使用的页面情况,但是可以知道过去使用页面的情况。LRU 将最近最久未使用的页面换出。

可以用栈来实现该算法,栈中存储页面的页面号。当进程访问一个页面时,将该页面的页面号从栈移除,并将它压入栈顶,这样,最近被访问的页面的页面号总是在栈顶,而最近最久未使用的页面的页面号总是在栈底。

五、设备管理

1. 磁盘调度算法

当多个进程同时请求访问磁盘时,需要进行磁盘调度来控制对磁盘的访问。磁盘调度的主要目标是使磁盘的平均寻道时间最少。

(1)先来先服务(FCFS)

根据进程请求访问磁盘的先后次序来进行调度。优点是公平和简单,缺点也很明显,因为未对寻道做任何优化,使平均寻道时间可能较长。

(2)最短寻道时间优先(SSTF)

要求访问的磁道与当前磁头所在磁道距离最近的优先进行调度。这种算法并不能保证平均寻道时间最短,但是比 FCFS 好很多。

(3)扫描算法(SCAN)

SSTF 会出现进行饥饿现象。考虑以下情况,新进程请求访问的磁道与磁头所在磁道的距离总是比一个在等待的进程来的近,那么等待的进程会一直等待下去。

当一个磁头自里向外移动时,移到最外侧会改变移动方向为自外向里,这种移动的规律类似于电梯的运行,因此又常称 SCAN 算法为电梯调度算法。

(4) 循环扫描算法(CSCAN)

CSCAN 对 SCAN 进行了改动,要求磁头始终沿着一个方向移动。

2. 对I/O设备的控制方式

(1)程序循环测试方式(程序查询式) .

是指用户进理使用。Start指令启动设备后,不断地执行指令,去测试所自动设备的状态寄存器。

数据寄存器:用来存放传输的数据

状态寄存器:用来记录设备当前所处状态

(2)中断方式

所谓“中断”是一种使CPU暂时中止正在执行的程序而转去处理特殊时间的操作。

引起中断的时间称为中断源。

程序中产生的中断,由CPU的某些错误结果(如,计算机溢出)产生的中断称为“内中断”,由外部设备控制器引起的中断称为“外中断”

(3)直接存储器存取方式(DMA 方式)

特点:能使I/0设备直接和内存储器进行成批数据的快速传输。

DMA控制器包括四个寄存器:数据寄存器,状态寄存器,地址寄存器,字节计数器

(4)通道方式

通道方式能够使CPU彻底从I/O中解放出来。CPU进行善后处理和启动。

通道是一个独立于CPU的,专门用来管理输入/输出操作的处理机。

通道是通过执行通道程序并与设备控制器共同实现对I/O设备的控制的。

它规定了设备应该执行的各种操作的顺序。由-系列通道指令所构成,CPU对I/O请求只去做启动和善后处理工作,输入/输出的管理以及数据传输等事宜,全部由通道独立完成。

六、文件管理

(1)目标:提高外存储空间的利用率

(2)主要任务:对用户文件和系统文件进行管理,方便用户使用,并保证文件的安全性

文件存储设备是以块为单位进行管理的

(3)所谓“文件”是指具有完整逻辑意义的一-组相关信息的集合,它是在磁盘上保存信息,而且能方便以后读取的方法,文件用符号名加以标识,这个符号名就被称为“文件名”

(4)文件的存取

顺序存取

随机存取

(5)磁盘空间的管理

a.磁盘是以块为单位进行分配的

b.磁盘与内存之间是 以磁盘块为信息传输的单位

c. 选定了块的大小,还要对它们进行管理,即要记住哪些已经分配,哪些仍然空闲。

d. 常采用的磁盘存储空间管理方案有:位示图,空闲块表,空闲块链

(6)文件的操作:

创建文件、删除文件、打开文件、关闭文件、读文件、写文件

(7)目录的层次结构

如果把所有文件的FCB都登记在一一个文件目录中,这样由文件名查文件目录项,直接就能够找到所需要的文件,那么就成这种文件目录为一级目录结构

优点:

简单,能实现目录管理中最基本的功能-按名存职

缺点:

查找速度慢,不允许重名,不便于实现文件共享

二级目录结构:

由“主目录”与“用户目录”二级构成,在主目录(根目录)中,每个目录项的内容只是给出文件主名以及它的目录所在的磁盘地址。

优点:

提高了检索目录的速度

b. 在不同的文件目录中,可以使用相同的文件名

c.不同用户还可使用不同的文件名访问系统中的同一个共享文件

缺点:

a. 若一个用户可以拥有很多文件,则查找时间仍然很长

b.用户无法对自己的文件进行再分类安排

以上是我对这本书大概学过内容的整理,但是对操作系统的学习远远不止于此,本学期学的内容还有很多我没有掌握的地方,很多地方也可以结合生活中的例子,化抽象为具体,我们就会更加清楚的了解它。

网站文章

  • MySQL事务基础知识

    MySQL事务基础知识

    目录1.数据库事务概述1.1 存储引擎支持情况1.2 事务基本概念1.3 事务的ACID特性1.4 事务的状态2.如何使用事务3.事务的隔离级别4.事务的常见分类1.数据库事务概述1.1 存储引擎支持...

    2024-01-30 22:03:59
  • 深入浅出C语言——C语言简介

    深入浅出C语言——C语言简介

    C语言的内容简介

    2024-01-30 22:03:52
  • Java中输入一个整数n,实现n的阶乘

    Java中输入一个整数n,实现n的阶乘

    n的阶乘:1!+2!+3!+…+n! public static void main(String[] args) { //2.输入一个整数n,实现n的阶乘。n*(n-1)*......*1 Scan...

    2024-01-30 22:03:46
  • 台式计算机有哪些特性,计算机的主要特点有哪些

    大家好,我是时间财富网智能客服时间君,上述问题将由我为大家进行解答。计算机具有以下几个主要特点:1、运算速度快目前最快的巨型机运行速度已达每秒100多亿次,这是传统计算工具所无法比拟的。随着科学技术的...

    2024-01-30 22:03:16
  • 逛逛GitHub

    逛逛GitHub

    基于 Spring Cloud Hoxton 、Spring Boot 2.3、 OAuth2 的RBAC权限管理系统,数据驱动视图的理念封装 element-ui,即使没有 vue 的使用经验也能快...

    2024-01-30 22:03:09
  • Leetcode--------字符串

    Leetcode--------字符串

    344. 反转字符串编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 char[] 的形式给出。不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决...

    2024-01-30 22:03:03
  • 掌握C语言中的操作符:编程必备技巧

    掌握C语言中的操作符:编程必备技巧

    详解C语言里的操作符。

    2024-01-30 22:02:32
  • Ant执行build文件时报input file XXX .jtl does not exist

    Ant执行build文件时报input file XXX .jtl does not exist

    Ant执行build文件时报input file XXX .jtl does not exist 最近突然想到,把Jmeter+Ant+Jenkins+git放到远程堡垒机上使用,就可以共享给其他人使...

    2024-01-30 22:02:26
  • 大数的取余运算

    问题描述: 给出两个数a,b,求a%b;(其中1^9) 分析: 由于数字太大,所以用字符数组进行处理比较方便,然后转化为数字即可。 举个例子:999 % 8; c = 9 > 8 //只要大于8,就求余 c = 9 % 8 ——> c = 1; c = 1 * 10 + 9 ——> c = 19 > 8;

    2024-01-30 22:02:19
  • Pycharm控制台中文输出乱码问题解决方案

    Pycharm控制台中文输出乱码问题解决方案

    Pycharm控制台中文输出乱码问题解决方法

    2024-01-30 22:01:48