实验4并发与调度.ppt
《实验4并发与调度.ppt》由会员分享,可在线阅读,更多相关《实验4并发与调度.ppt(28页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、操作系统原理实验操作系统原理实验安全性安全性安全性安全性 输输入入入入/输输出出出出管理管理管理管理 调调度度度度 存存存存储储器管理器管理器管理器管理进进程描述程描述程描述程描述与控制与控制与控制与控制 并并并并发发性性性性 文件管理文件管理文件管理文件管理 联联网网网网 操作系统的各个主题操作系统的各个主题操作系统的各个主题操作系统的各个主题 粗粗粗粗线线表示从表示从表示从表示从设计设计和和和和实现实现的角度考的角度考的角度考的角度考虑虑关系非常关系非常关系非常关系非常紧紧密密密密实验实验4 并发与调度并发与调度通过对事件和互斥体对象以及对文件和文件映通过对事件和互斥体对象以及对文件和文件
2、映通过对事件和互斥体对象以及对文件和文件映通过对事件和互斥体对象以及对文件和文件映射对象的了解,来加深对操作系统进程同步、射对象的了解,来加深对操作系统进程同步、射对象的了解,来加深对操作系统进程同步、射对象的了解,来加深对操作系统进程同步、线程同步的理解;通过线程同步的理解;通过线程同步的理解;通过线程同步的理解;通过LinuxLinuxLinuxLinux并发程序的调试,并发程序的调试,并发程序的调试,并发程序的调试,学习操作系统并发程序的工作方式学习操作系统并发程序的工作方式学习操作系统并发程序的工作方式学习操作系统并发程序的工作方式 实验实验4.1 Windows 2000 4.1 W
3、indows 2000 线线程同步程同步程同步程同步 实验实验4.2 Windows 2000 4.2 Windows 2000 线线程程程程间间的通的通的通的通讯讯 实验实验4.3 Linux 4.3 Linux 并并并并发发程序程序程序程序设计设计实验估计时间:实验估计时间:实验估计时间:实验估计时间:120120分钟分钟分钟分钟,难度系数:,难度系数:,难度系数:,难度系数:4 44.1 Windows 2000 线程同步线程同步 Windows 2000 Windows 2000提供的常用对象可分成三类:核心提供的常用对象可分成三类:核心提供的常用对象可分成三类:核心提供的常用对象可分
4、成三类:核心应用效劳、线程同步和线程间通讯。其中,开发人应用效劳、线程同步和线程间通讯。其中,开发人应用效劳、线程同步和线程间通讯。其中,开发人应用效劳、线程同步和线程间通讯。其中,开发人员可以使用线程同步对象来协调线程和进程的工作,员可以使用线程同步对象来协调线程和进程的工作,员可以使用线程同步对象来协调线程和进程的工作,员可以使用线程同步对象来协调线程和进程的工作,以使其共享信息并执行任务。此类对象包括以使其共享信息并执行任务。此类对象包括以使其共享信息并执行任务。此类对象包括以使其共享信息并执行任务。此类对象包括互锁数据互锁数据互锁数据互锁数据临界段临界段临界段临界段事件事件事件事件互斥
5、体互斥体互斥体互斥体信号信号信号信号背景知识背景知识多线程编程中关键的一步是保护所有的共享资源,多线程编程中关键的一步是保护所有的共享资源,多线程编程中关键的一步是保护所有的共享资源,多线程编程中关键的一步是保护所有的共享资源,工具主要有互锁函数、临界段和互斥体等;另一个工具主要有互锁函数、临界段和互斥体等;另一个工具主要有互锁函数、临界段和互斥体等;另一个工具主要有互锁函数、临界段和互斥体等;另一个实质性局部是协调线程使其完成应用程序的任务,实质性局部是协调线程使其完成应用程序的任务,实质性局部是协调线程使其完成应用程序的任务,实质性局部是协调线程使其完成应用程序的任务,为此,可利用内核中的
6、事件对象和信号为此,可利用内核中的事件对象和信号为此,可利用内核中的事件对象和信号为此,可利用内核中的事件对象和信号在进程内或进程间实现线程同步的最方便的方法是在进程内或进程间实现线程同步的最方便的方法是在进程内或进程间实现线程同步的最方便的方法是在进程内或进程间实现线程同步的最方便的方法是使用事件对象,这一组内核对象允许一个线程对其使用事件对象,这一组内核对象允许一个线程对其使用事件对象,这一组内核对象允许一个线程对其使用事件对象,这一组内核对象允许一个线程对其受信状态进行直接控制受信状态进行直接控制受信状态进行直接控制受信状态进行直接控制背景知识背景知识而互斥体那么是另一个可命名且平安的内
7、核对象,而互斥体那么是另一个可命名且平安的内核对象,而互斥体那么是另一个可命名且平安的内核对象,而互斥体那么是另一个可命名且平安的内核对象,其主要目的是引导对共享资源的访问。拥有单一访其主要目的是引导对共享资源的访问。拥有单一访其主要目的是引导对共享资源的访问。拥有单一访其主要目的是引导对共享资源的访问。拥有单一访问资源的线程创立互斥体,所有想要访问该资源的问资源的线程创立互斥体,所有想要访问该资源的问资源的线程创立互斥体,所有想要访问该资源的问资源的线程创立互斥体,所有想要访问该资源的线程应该在实际执行操作之前获得互斥体,而在访线程应该在实际执行操作之前获得互斥体,而在访线程应该在实际执行操
8、作之前获得互斥体,而在访线程应该在实际执行操作之前获得互斥体,而在访问结束时立即释放互斥体,以允许下一个等待线程问结束时立即释放互斥体,以允许下一个等待线程问结束时立即释放互斥体,以允许下一个等待线程问结束时立即释放互斥体,以允许下一个等待线程获得互斥体,然后接着进行下去获得互斥体,然后接着进行下去获得互斥体,然后接着进行下去获得互斥体,然后接着进行下去与事件对象类似,互斥体容易创立、翻开、使用并与事件对象类似,互斥体容易创立、翻开、使用并与事件对象类似,互斥体容易创立、翻开、使用并与事件对象类似,互斥体容易创立、翻开、使用并去除。利用去除。利用去除。利用去除。利用CreateMutex()A
9、PICreateMutex()API可创立互斥体,创立可创立互斥体,创立可创立互斥体,创立可创立互斥体,创立时还可以指定一个初始的拥有权标志,通过使用这时还可以指定一个初始的拥有权标志,通过使用这时还可以指定一个初始的拥有权标志,通过使用这时还可以指定一个初始的拥有权标志,通过使用这个标志,只有当线程完成了资源的所有的初始化工个标志,只有当线程完成了资源的所有的初始化工个标志,只有当线程完成了资源的所有的初始化工个标志,只有当线程完成了资源的所有的初始化工作时,才允许创立线程释放互斥体作时,才允许创立线程释放互斥体作时,才允许创立线程释放互斥体作时,才允许创立线程释放互斥体背景知识背景知识为了
10、获得互斥体,首先,想要访问调用的线程可使为了获得互斥体,首先,想要访问调用的线程可使为了获得互斥体,首先,想要访问调用的线程可使为了获得互斥体,首先,想要访问调用的线程可使用用用用OpenMutex()APIOpenMutex()API来获得指向对象的句柄;然后,来获得指向对象的句柄;然后,来获得指向对象的句柄;然后,来获得指向对象的句柄;然后,线程将这个句柄提供给一个等待函数。当内核将互线程将这个句柄提供给一个等待函数。当内核将互线程将这个句柄提供给一个等待函数。当内核将互线程将这个句柄提供给一个等待函数。当内核将互斥体对象发送给等待线程时,就说明该线程获得了斥体对象发送给等待线程时,就说明
11、该线程获得了斥体对象发送给等待线程时,就说明该线程获得了斥体对象发送给等待线程时,就说明该线程获得了互斥体的拥有权。当线程获得拥有权时,线程控制互斥体的拥有权。当线程获得拥有权时,线程控制互斥体的拥有权。当线程获得拥有权时,线程控制互斥体的拥有权。当线程获得拥有权时,线程控制了对共享资源的访问了对共享资源的访问了对共享资源的访问了对共享资源的访问必须设法尽快地放弃互斥必须设法尽快地放弃互斥必须设法尽快地放弃互斥必须设法尽快地放弃互斥体。放弃共享资源时需要在该对象上调用体。放弃共享资源时需要在该对象上调用体。放弃共享资源时需要在该对象上调用体。放弃共享资源时需要在该对象上调用ReleaseMut
12、e()APIReleaseMute()API。然后系统负责将互斥体拥有权。然后系统负责将互斥体拥有权。然后系统负责将互斥体拥有权。然后系统负责将互斥体拥有权传递给下一个等待着的线程传递给下一个等待着的线程传递给下一个等待着的线程传递给下一个等待着的线程(由到达时间决定顺序由到达时间决定顺序由到达时间决定顺序由到达时间决定顺序)背景知识背景知识在本实验中,通过对事件和互斥体对象的了解,来在本实验中,通过对事件和互斥体对象的了解,来在本实验中,通过对事件和互斥体对象的了解,来在本实验中,通过对事件和互斥体对象的了解,来加深对加深对加深对加深对Windows 2000Windows 2000线程同步
13、的理解。线程同步的理解。线程同步的理解。线程同步的理解。回忆系统进程、线程的有关概念,加深对回忆系统进程、线程的有关概念,加深对回忆系统进程、线程的有关概念,加深对回忆系统进程、线程的有关概念,加深对Windows Windows 20002000线程的理解线程的理解线程的理解线程的理解了解事件和互斥体对象了解事件和互斥体对象了解事件和互斥体对象了解事件和互斥体对象通过分析实验程序,了解管理事件对象的通过分析实验程序,了解管理事件对象的通过分析实验程序,了解管理事件对象的通过分析实验程序,了解管理事件对象的APIAPI了解在进程中如何使用事件对象了解在进程中如何使用事件对象了解在进程中如何使用
14、事件对象了解在进程中如何使用事件对象了解在进程中如何使用互斥体对象了解在进程中如何使用互斥体对象了解在进程中如何使用互斥体对象了解在进程中如何使用互斥体对象了解父进程创立子进程的程序设计方法了解父进程创立子进程的程序设计方法了解父进程创立子进程的程序设计方法了解父进程创立子进程的程序设计方法实验目的实验目的在开始本实验之前,请回忆教科书的相关内容在开始本实验之前,请回忆教科书的相关内容在开始本实验之前,请回忆教科书的相关内容在开始本实验之前,请回忆教科书的相关内容需要做以下准备需要做以下准备需要做以下准备需要做以下准备一台运行一台运行一台运行一台运行Windows 2000 Professio
15、nalWindows 2000 Professional操作系统的计操作系统的计操作系统的计操作系统的计算机算机算机算机计算机中需安装专业版或企业版计算机中需安装专业版或企业版计算机中需安装专业版或企业版计算机中需安装专业版或企业版工具工具/准备工作准备工作事件对象事件对象事件对象事件对象互斥体对象互斥体对象互斥体对象互斥体对象 实验内容与步骤实验内容与步骤实验估计时间:实验估计时间:实验估计时间:实验估计时间:120120分钟分钟分钟分钟,难度系数:,难度系数:,难度系数:,难度系数:5 54.2 Windows 2000 线程间的通讯线程间的通讯Windows 2000Windows 20
16、00提供的线程间通讯类内核对象允提供的线程间通讯类内核对象允提供的线程间通讯类内核对象允提供的线程间通讯类内核对象允许同一进程或跨进程的线程之间互相发送信息,许同一进程或跨进程的线程之间互相发送信息,许同一进程或跨进程的线程之间互相发送信息,许同一进程或跨进程的线程之间互相发送信息,包括文件、文件映射、邮件位和命名管道等,包括文件、文件映射、邮件位和命名管道等,包括文件、文件映射、邮件位和命名管道等,包括文件、文件映射、邮件位和命名管道等,其中最常用的是文件和文件映射。这类对象允其中最常用的是文件和文件映射。这类对象允其中最常用的是文件和文件映射。这类对象允其中最常用的是文件和文件映射。这类对
17、象允许一个线程很容易地向同一进程或其他进程中许一个线程很容易地向同一进程或其他进程中许一个线程很容易地向同一进程或其他进程中许一个线程很容易地向同一进程或其他进程中的另一线程发送信息的另一线程发送信息的另一线程发送信息的另一线程发送信息背景知识背景知识文件对象文件对象文件对象文件对象文件对象是人们所熟悉的永久存储的传统元素。将文件对象是人们所熟悉的永久存储的传统元素。将文件对象是人们所熟悉的永久存储的传统元素。将文件对象是人们所熟悉的永久存储的传统元素。将一个文件看作是内核对象可使开发人员获得比标准一个文件看作是内核对象可使开发人员获得比标准一个文件看作是内核对象可使开发人员获得比标准一个文件
18、看作是内核对象可使开发人员获得比标准C+C+文件操作更为强大的功能文件操作更为强大的功能文件操作更为强大的功能文件操作更为强大的功能内核允许开发人员在系统设备或网络上创立代表永内核允许开发人员在系统设备或网络上创立代表永内核允许开发人员在系统设备或网络上创立代表永内核允许开发人员在系统设备或网络上创立代表永久存储数据块的文件对象。这些文件对象是对永久久存储数据块的文件对象。这些文件对象是对永久久存储数据块的文件对象。这些文件对象是对永久久存储数据块的文件对象。这些文件对象是对永久存储数据的低级访问者;用存储数据的低级访问者;用存储数据的低级访问者;用存储数据的低级访问者;用C+C+运行库或其他
19、方法运行库或其他方法运行库或其他方法运行库或其他方法翻开的所有文件最终都要变成对翻开的所有文件最终都要变成对翻开的所有文件最终都要变成对翻开的所有文件最终都要变成对CreateFile()APICreateFile()API的的的的调用调用调用调用CreateFile()CreateFile()函数分配一个内核对象来代表一个永函数分配一个内核对象来代表一个永函数分配一个内核对象来代表一个永函数分配一个内核对象来代表一个永久的文件。当在磁盘上创立一个新文件或当翻开一久的文件。当在磁盘上创立一个新文件或当翻开一久的文件。当在磁盘上创立一个新文件或当翻开一久的文件。当在磁盘上创立一个新文件或当翻开一
20、个已经存在的文件时,就调用这个个已经存在的文件时,就调用这个个已经存在的文件时,就调用这个个已经存在的文件时,就调用这个APIAPI背景知识背景知识 创创立立立立调调用比用比用比用比创创立事件、互斥体或信号量要复立事件、互斥体或信号量要复立事件、互斥体或信号量要复立事件、互斥体或信号量要复杂杂。首先必。首先必。首先必。首先必须须在在在在lpFilenamelpFilename中指定中指定中指定中指定对对象名,并且要指向文件系象名,并且要指向文件系象名,并且要指向文件系象名,并且要指向文件系统统中中中中所所所所访问访问的位置。接着必的位置。接着必的位置。接着必的位置。接着必须须用用用用dwDes
21、iredAccessdwDesiredAccess参数提供所参数提供所参数提供所参数提供所需的需的需的需的访问级别访问级别 由由由由创创立函数要求的共享模式参数立函数要求的共享模式参数立函数要求的共享模式参数立函数要求的共享模式参数dwShareModedwShareMode可以指定可以指定可以指定可以指定当另一当另一当另一当另一进进程企程企程企程企图图同同同同时访问时访问数据数据数据数据时时会会会会发发生什么。与所有其生什么。与所有其生什么。与所有其生什么。与所有其他第一他第一他第一他第一级级内核内核内核内核对对象一象一象一象一样样,可以利用,可以利用,可以利用,可以利用lpSecurity
22、AttributeslpSecurityAttributes参数指定所参数指定所参数指定所参数指定所创创立立立立对对象的平安性。接着,要通象的平安性。接着,要通象的平安性。接着,要通象的平安性。接着,要通过过dwCreationDispositiondwCreationDisposition参数告参数告参数告参数告诉创诉创立函数,如果数据在立函数,如果数据在立函数,如果数据在立函数,如果数据在指定的永久存指定的永久存指定的永久存指定的永久存储储介介介介质质中存在或不存在中存在或不存在中存在或不存在中存在或不存在时时的行的行的行的行为为背景知识背景知识 可以使用可以使用可以使用可以使用dwFla
23、gsAndAttributesdwFlagsAndAttributes参数来指定文件的属性参数来指定文件的属性参数来指定文件的属性参数来指定文件的属性 (如只如只如只如只读读),并确定,并确定,并确定,并确定对对数据所数据所数据所数据所执执行的行的行的行的读读写操作的行写操作的行写操作的行写操作的行为为。最。最。最。最后一个参数后一个参数后一个参数后一个参数hTemplateFilehTemplateFile可指定另一个文件可指定另一个文件可指定另一个文件可指定另一个文件对对象作象作象作象作为为模模模模板,以便板,以便板,以便板,以便为为新新新新创创立的文件复制属性或立的文件复制属性或立的文件
24、复制属性或立的文件复制属性或扩扩展属性展属性展属性展属性 Windows 2000Windows 2000系系系系统统中包括中包括中包括中包括许许多文件多文件多文件多文件对对象的工具函数象的工具函数象的工具函数象的工具函数APIAPI 通常可以使用通常可以使用通常可以使用通常可以使用ReadFile()ReadFile()和和和和WriteFile()APIWriteFile()API在永久存在永久存在永久存在永久存储储和和和和应应用程序用程序用程序用程序间间通通通通过过文件文件文件文件对对象来移象来移象来移象来移动动数据。因数据。因数据。因数据。因为创为创立立立立调调用将用将用将用将对对象的
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实验 并发 调度
限制150内