收藏 分销(赏)

操作系统linux系统下实现pv操作.doc

上传人:a199****6536 文档编号:2228449 上传时间:2024-05-23 格式:DOC 页数:21 大小:383.98KB 下载积分:10 金币
下载 相关 举报
操作系统linux系统下实现pv操作.doc_第1页
第1页 / 共21页
操作系统linux系统下实现pv操作.doc_第2页
第2页 / 共21页


点击查看更多>>
资源描述
计算机科学与通信工程学院 操作系统课程设计报告 题目:linux系统下实现PV操作 班级: 软件工程1401 姓名: 学号: 3 指导老师: 2016年12月27日 目录 一、 实验题目 3 二、 实验目的和要求 3 三、 环境配置 4 四、 设计思路 6 五、 代码实现 7 六、 总结 17 一、 实验题目 1. Linux 系统简单使用 (1) 认识Linux (2) ubuntu安装 (3) 终端的简单使用 (4) python3.5.2源码安装 2. 多线程和多进程同步方法解决水果分配问题: 水果分配的问题: 桌上有一只盘子,每次只能放入5只水果。爸爸专放苹果, 妈妈专放橘子,一个儿子专等吃盘子中的橘子,一个女儿专等吃盘子中的苹果.用P,V操作实现爸爸、妈妈、儿子、女儿进程的同步控制。 补充:设有两个篮子,分别有若干个苹果或橘子,爸爸和妈妈将每次从水果篮子中拿出一个水果放入水果盘中,儿子女儿则挑选各自喜欢的水果。 (1) 分析问题,写出伪代码 (2) 线程实现 (3) 进程实现 二、 实验目的和要求 1. 认识和学会使用linux系统: Linux 是一种可以在PC机上执行的类似UNIX的操作系统,是一个完全免费的操作系统。1991年,芬兰学生Linus Torvalds开发了这个操作系统的核心部分,因为是Linus 改良的minix系统,故称之为Linux. 2. 理解线程和进程的互斥和同步原理: 同步是操作系统级别的概念,是在多道程序的环境下,存在着不同的制约关系,为了协调这种互相制约的关系,实现资源共享和进程协作,从而避免进程之间的冲突,引入了进程同步。 进程互斥是间接制约关系。当一个进程进入临界区使用临界资源时,另一个进程必须等待。只有当使用临界资源的进程退出临界区后,这个进程才会解除阻塞状态。 3. 使用信号量和互斥量解决问题: 通过设置一个表示资源个数的信号量S,通过对信号量S的P和V操作来实现进程的的互斥。 通过设置一个表示资源个数的信号量S,通过对信号量S的P和V操作来实现进程的的互斥。 P和V操作分别来自荷兰语Passeren和Vrijgeven,分别表示占有和释放。P V操作是操作系统的原语,意味着具有原子性。 P操作首先减少信号量,表示有一个进程将占用或等待资源,然后检测S是否小于0,如果小于0则阻塞,如果大于0则占有资源进行执行。 V操作是和P操作相反的操作,首先增加信号量,表示占用或等待资源的进程减少了1个。然后检测S是否小于0,如果小于0则唤醒等待使用S资源的其它进程。 三、 环境配置 1. 安装ubuntu (1) 下载系统镜像,ubuntu-16.04.1-desktop-amd64.iso (2) 制作启动U盘,使用Ultraiso软件将系统镜像写入U盘 (3) 开机进入BIOS界面,从U盘启动。 (4) 对磁盘分区,等待安装结束。 (5) 设置root密码,sudo passwd root 命令后输入两遍密码。 2. 熟悉ubuntu的使用 常用命令: (1) su命令,切换用户 (2) pwd命令,打印当前工作目录的绝对路径 (3) ls命令,打印当前目录下的文件 (4) cd命令,切换工作目录 (5) mv命令,移动文件或目录 (6) rm命令,删除文件或目录 (7) shutdown命令,关闭计算机 (8) reboot命令,重启电脑 (9) tar命令,解压命令 3. 安装vim编辑器 在终端下运行apt-get install –y vim即可。 安装结束后,输入vim命令,显示如下图就说明安装成功: Figure 1 安装vim后输入vim显示的结果 4. 源码安装python3.5.2 因为linux内置的python的版本为2.7.5,所以为了程序设计的方便,使用3.5.2版本的。终端下输入python即可进入python交互模式。 安装前: Figure 2 内置python运行结果 安装步骤: (1) 进入下载目录,tar –zxvf Python-3.5.2.tar.gz 解压到当前目录下 (2) 进入解压目录,cd Python-3.5.2 (3) 验证系统配置,./configure (4) 编译和安装,make && make install (5) 建立软链接,在/usr/bin目录下生成python3的软链接文件 安装结果: Figure 3 python3安装结果 四、 设计思路 1. 题目分析: father、mather、son、daughter是四个线程或进程。 盘子plate是它们共享的变量,对盘子的操作要互斥。 Father和daughter要对apple同步。 Mother和son要对orange同步。 2. 伪代码: father: while(True): p(empty) p(mutex) put apple v(mutex) v(apple) mother: while(True): p(empty) p(mutex) put orange v(mutex) v(orange) son: while(True): p(orange) p(mutex) get orange v(mutex) v(empty) daughter: while(True): p(apple) p(mutex) get apple v(mutex) v(empty) 五、 代码实现 1. 线程实现 (1) 原理 threading.py模块提供了对线程的操作。 创建线程threading.Thread(target, args),target是要运行的函数,args是函数所需的参数。 创建信号量threading.Semaphore(value), value是信号量的初始值。acquire() 信号量-1,当为0时,阻塞当前线程。release() 信号量+1,大于0,唤醒等待此信号量的一个线程。 创建互斥锁,threading.Lock(), acquire() 加锁,release()解锁。 (2) 变量 定义list类型的 apples_basket 存放所有的苹果 定义list类型的 oranges_basket 存放所有的橘子 定义list类型的plate当做水果盘,可以放入苹果和橘子 定义方法father ,用于将苹果放入水果盘,也就是把apples_basket的一个苹果,放入plate列表中。并打印相关信息。 定义方法mather ,用于将苹果放入水果盘,也就是把oranges_basket的一个橘子,放入plate列表中。并打印相关信息。 定义方法son ,用于从水果盘取出一个橘子,也就是把plate的一个橘子,拿出来,并打印相关信息。 定义方法daughter ,用于从水果盘取出一个苹果,也就是把plate的一个苹果,拿出来,并打印相关信息。 (3) 代码 import random import threading import time empty = threading.Semaphore(5) # 盘子的容量 apple = threading.Semaphore(0) # 同步苹果的信号量 orange = threading.Semaphore(0) # 同步橘子的信号量 mutex = threading.Event() # 表示四个进程互斥的访问盘子 plate = list() # 模拟水果盘 lock = threading.Lock() # plate互斥锁 mutex.set() # 设置为True def father(basket): global empty, mutex, lock, apple while len(basket) != 0: # 当苹果篮子中没有苹果,则终止 # 1.p(empty) empty.acquire() # 将容量empty减去1 # 2.p(mutex) mutex.clear() # mutex设置为False 其它线程将等待 # 3.put apple if lock.acquire(): temp = basket.pop() plate.append(temp) # 从苹果篮子里拿出一个苹果放入水果盘 print('->father put an apple({0}) into plate.'.format(temp)) print(' current plate = ', plate) lock.release() # 4.v(mutex) mutex.set() # mutex设置为True, 其它线程可以使用 # 5.v(apple) apple.release() time.sleep(random.random()) def mother(basket): global empty, mutex, lock, orange while len(basket) != 0: # 当橘子篮子中没有橘子,则终止 # 1.p(empty) empty.acquire() # 将容量empty减去1 # 2.p(mutex) mutex.clear() # mutex设置为False 其它线程将等待 # 3.put(orange) if lock.acquire(): temp = basket.pop() plate.append(temp) print('->mother put an orange({0}) into plate.'.format(temp)) print(' current plate = ', plate) lock.release() # 4.v(mutex) mutex.set() # mutex设置为True, 其它线程可以使用 # 5.v(orange) orange.release() time.sleep(random.random()) def son(count): global empty, mutex, lock, orange for i in range(count): # 1.p(orange) orange.acquire() # orange -1 # 2.p(mutex) mutex.clear() # mutex设置为False 其它线程将等待 # 3.get orange if lock.acquire(): for fruit in plate: if fruit.startswith('Orange'): temp = fruit plate.remove(fruit) break print('->son take an orange({0}) from plate.'.format(temp)) print(' current plate = ', plate) lock.release() # 4.v(mutex) mutex.set() # mutex设置为True, 其它线程可以使用 # 5.v(empty) empty.release() # 将empty + 1 time.sleep(random.random()) def daughter(count): global empty, mutex, lock, apple for i in range(count): # 1.p(apple) apple.acquire() # apple -1 # 2.p(mutex) mutex.clear() # mutex设置为False 其它线程将等待 # 3.get apple if lock.acquire(): for fruit in plate: if fruit.startswith('Apple'): temp = fruit plate.remove(fruit) break print('->daughter take an apple({0}) from plate'.format(temp)) print(' current plate = ', plate) lock.release() # 4.v(mutex) mutex.set() # mutex设置为True, 其它线程可以使用 # 5.v(empty) empty.release() # 将empty + 1 time.sleep(random.random()) if __name__ == '__main__': # 初始化苹果和橘子的个数 apples_basket = ['Apple-A', 'Apple-B', 'Apple-C', "Apple-D"] # 模拟苹果篮子,一共有4个苹果要放入水果盘 oranges_basket = ['Orange-A', 'Orange-B', 'Orange-C'] # 模拟橘子篮子,一共有3个橘子要放入水果盘 # 创建4个线程 father = threading.Thread(name='Father', target=father, args=(apples_basket, )) # father 线程 mother = threading.Thread(name='Mother', target=mother, args=(oranges_basket, )) # mother 线程 son = threading.Thread(name='Son', target=son, args=(len(oranges_basket), )) # son 线程 daughter = threading.Thread(name='Daughter', target=daughter, args=(len(apples_basket), )) # daughter 线程 # 启动线程 daughter.start() son.start() father.start() mother.start() (4) 结果 Figure 4线程实现结果 2. 进程实现 (1) 原理 multiprocessing.py模块提供了对线程的操作。 创建线程multiprocessing.Process(target, args),target是要运行的函数,args是函数所需的参数。 创建信号量multiprocessing.Semaphore(value), value是信号量的初始值。acquire() 信号量-1,当为0时,阻塞当前线程。release() 信号量+1,大于0,唤醒等待此信号量的一个线程。 创建互斥锁,multiprocessing.Lock(), acquire() 加锁,release()解锁。 (2) 变量 定义list类型的 apples_basket 存放所有的苹果 定义list类型的 oranges_basket 存放所有的橘子 定义list类型的plate当做水果盘,可以放入苹果和橘子 定义方法father ,用于将苹果放入水果盘,也就是把apples_basket的一个苹果,放入plate列表中。并打印相关信息。 定义方法mather ,用于将苹果放入水果盘,也就是把oranges_basket的一个橘子,放入plate列表中。并打印相关信息。 定义方法son ,用于从水果盘取出一个橘子,也就是把plate的一个橘子,拿出来,并打印相关信息。 定义方法daughter ,用于从水果盘取出一个苹果,也就是把plate的一个苹果,拿出来,并打印相关信息。 (3) 代码 import random import multiprocessing import time empty = multiprocessing.Semaphore(5) # 盘子的容量 apple = multiprocessing.Semaphore(0) # 同步苹果的信号量 orange = multiprocessing.Semaphore(0) # 同步橘子的信号量 mutex = multiprocessing.Event() # 表示四个进程互斥的访问盘子 manager = multiprocessing.Manager() plate = manager.list() # 模拟水果盘 lock = multiprocessing.Lock() # plate互斥锁 mutex.set() # 设置为True def father(basket): global empty, mutex, lock, apple while len(basket) != 0: # 当苹果篮子中没有苹果,则终止 # 1.p(empty) empty.acquire() # 将容量empty减去1 # 2.p(mutex) mutex.clear() # mutex设置为False 其它线程将等待 # 3.put apple if lock.acquire(): temp = basket.pop() plate.append(temp) # 从苹果篮子里拿出一个苹果放入水果盘 print('->father put an apple({0}) into plate.'.format(temp)) print(' current plate = ', plate) lock.release() # 4.v(mutex) mutex.set() # mutex设置为True, 其它线程可以使用 # 5.v(apple) apple.release() time.sleep(random.random()) def mother(basket): global empty, mutex, lock, orange while len(basket) != 0: # 当橘子篮子中没有橘子,则终止 # 1.p(empty) empty.acquire() # 将容量empty减去1 # 2.p(mutex) mutex.clear() # mutex设置为False 其它进程将等待 # 3.put(orange) if lock.acquire(): temp = basket.pop() plate.append(temp) print('->mother put an orange({0}) into plate.'.format(temp)) print(' current plate = ', plate) lock.release() # 4.v(mutex) mutex.set() # mutex设置为True, 其它进程可以使用 # 5.v(orange) orange.release() time.sleep(random.random()) def son(count): global empty, mutex, lock, orange for i in range(count): # 1.p(orange) orange.acquire() # orange -1 # 2.p(mutex) mutex.clear() # mutex设置为False 其它进程将等待 # 3.get orange if lock.acquire(): for fruit in plate: if fruit.startswith('Orange'): temp = fruit plate.remove(fruit) break print('->son take an orange({0}) from plate.'.format(temp)) print(' current plate = ', plate) lock.release() # 4.v(mutex) mutex.set() # mutex设置为True, 其它进程可以使用 # 5.v(empty) empty.release() # 将empty + 1 time.sleep(random.random()) def daughter(count): global empty, mutex, lock, apple for i in range(count): # 1.p(apple) apple.acquire() # apple -1 # 2.p(mutex) mutex.clear() # mutex设置为False 其它进程将等待 # 3.get apple if lock.acquire(): for fruit in plate: if fruit.startswith('Apple'): temp = fruit plate.remove(fruit) break print('->daughter take an apple({0}) from plate'.format(temp)) print(' current plate = ', plate) lock.release() # 4.v(mutex) mutex.set() # mutex设置为True, 其它进程可以使用 # 5.v(empty) empty.release() # 将empty + 1 time.sleep(random.random()) if __name__ == '__main__': # 初始化苹果和橘子的个数 apples_basket = ['Apple-A', 'Apple-B', 'Apple-C', "Apple-D"] # 模拟苹果篮子,一共有4个苹果要放入水果盘 oranges_basket = ['Orange-A', 'Orange-B', 'Orange-C'] # 模拟橘子篮子,一共有3个橘子要放入水果盘 # 创建4个进程 father = multiprocessing.Process(name='Father', target=father, args=(apples_basket, )) # father 进程 mother = multiprocessing.Process(name='Mother', target=mother, args=(oranges_basket, )) # mother 进程 son = multiprocessing.Process(name='Son', target=son, args=(len(oranges_basket), )) # son 进程 daughter = multiprocessing.Process(name='Daughter', target=daughter, args=(len(apples_basket), )) # daughter 进程 # 启动进程 daughter.start() son.start() father.start() mother.start() daughter.join() son.join() father.join() mother.join() print("End !") (4) 结果 Figure 5进程实现结果 六、 总结 因为之前就在慕课网上看过linux使用的教程,学过centos7字符界面的使用。在课程设计前就装好了win10 + Ubuntu 16.04 LTS双系统。所以在熟悉linux使用上并没有花时间。 初期使用linux最大的麻烦就是安装软件。安装方式有源码安装和二进制包安装。使用熟练后装软件的速度还是比windows上慢。不过各有优缺点。因为软件开发在linux上比较方便,就逐渐从windows平台转移到linux上了。 Ubuntu这个发行版本的图形界面做的还是比较美观的。 使用linux的过程中让我对多用户操作系统更加了解,虽然windows系统也是多用户操作系统,但是平常使用的时候都是超级管理员身份,所以感触不深。Linux对文件权限管理十分严格,只有相应的用户身份才能获得使用这个文件的特定权限。 使用python的原因是python的语法简洁、优雅。没有c和c++的指针,实现比较方便。Java的代码太过繁琐,不适合快速实现想法。 Python的中文文档相对较少,有些模块是对c的封装,看不见源码。所以在学习threading.py 和multiprocessing.py 的时候百度的东西十分琐碎,影响了开发速度。 本次实验后,对线程和进程也有了更深更具体的体会。进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位。线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位。线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源。 具体区别如下: 地址空间和其它资源:进程间相互独立,同一进程的各线程间共享。某进程内的线程在其它进程不可见。 通信:进程间通信IPC,线程间可以直接读写进程数据段(如全局变量)来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性。 调度和切换:线程上下文切换比进程上下文切换要快得多。 Python对线程的支持不如java等语言好。因为Python多线程下,每个线程的执行方式: 1.取GIL 2.执行代码直到sleep或者是python虚拟机将其挂起。 3.释放GIL 可见,某个线程想要执行,必须先拿到GIL,我们可以把GIL看作是“通行证”,并且在一个python进程中,GIL只有一个。拿不到通行证的线程,就不允许进入CPU执行。每次释放GIL锁,线程进行锁竞争、切换线程,会消耗资源。并且由于GIL锁存在,python里一个进程永远只能同时执行一个线程(拿到GIL的线程才能执行),这就是为什么在多核CPU上,python的多线程效率并不高。 但是并不意味着python的多线程就没有用了,在执行密集型代码(文件处理、网络爬虫等),多线程能够有效提升效率(单线程下有IO操作会进行IO等待,造成不必要的时间浪费,所以python的多线程对IO密集型代码比较友好。 在多核CPU下,用多进程效率高,在单核CPU下,使用多线程效率高。 此次课程设计收获最大的还是学会了,怎么用信号量控制线程和多个进程之间的同步和互斥。目 录 第1章 总 论 3 1.1. 项目背景与概况 3 1.2. 主要技术经济指标 7 1.3. 问题与建议 8 第2章 项目投资环境与市场研究 9 2.1. 投资环境分析 9 2.2. 区域房地产市场分析 11 2.3. 销售预测 15 2.4. 营销策略 19 第3章 建设规模与项目开发条件 21 3.1. 建设规模 21 3.2. 项目概况现状 21 3.3. 项目建设条件 22 第4章 建筑方案 26 4.1. 设计依据 26 4.2. 项目设计主题和开发理念 26 4.3. 项目总体规划方案 27 4.4. 建筑设计 28 4.5. 结构设计 29 4.6. 给排水设计 30 第5章 节能节水措施 32 5.1. 设计依据 32 5.2. 建筑部分节能设计 32 第6章 环境影响评价 33 6.1. 编制依据 33 6.2. 环境现状 33 6.3. 项目建设对环境的影响 34 6.4. 环境保护措施 34 第7章 劳动卫生与消防 35 7.1. 指导思想 35 7.2. 职业安全卫生健康对策与措施 35 7.3. 消防设计 36 第8章 组织机构与人力资源配置 38 8.1. 组织机构 38 8.2. 人力资源配置 38 第9章 项目实施进度 39 9.1. 项目开发期 39 9.2. 项目实施进度安排 39 9.3. 项目实施过程控制措施 39 第10章 项目招投标 41 10.1. 工程项目招标投标概述 41 10.2. 工程项目招标投标因素分析 42 10.3. 招标依据 44 10.4. 招标范围 44 10.5. 招标方式 44 第11章 投资估算与资金筹措 45 11.1. 投资估算 45 11.2. 资金筹措 45 第12章 财务评价 47 12.1. 项目评估依据 47 12.2. 财务评价基础数据的选择 47 12.3. 财务评价 47 12.4. 不确定性分析 48 第13章 社会评价 49 13.1. 项目对社会的影响分析 49 13.2. 风险分析 50 13.3. 社会评价结论 51 第14章 研究结论与建议 52 14.1. 可行性研究结论 52 14.2. 建议 52 21 / 21
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 通信科技 > 操作系统相关

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服