科技: 人物 企业 技术 IT业 TMT
科普: 自然 科学 科幻 宇宙 科学家
通信: 历史 技术 手机 词典 3G馆
索引: 分类 推荐 专题 热点 排行榜
互联网: 广告 营销 政务 游戏 google
新媒体: 社交 博客 学者 人物 传播学
新思想: 网站 新书 新知 新词 思想家
图书馆: 文化 商业 管理 经济 期刊
网络文化: 社会 红人 黑客 治理 亚文化
创业百科: VC 词典 指南 案例 创业史
前沿科技: 清洁 绿色 纳米 生物 环保
知识产权: 盗版 共享 学人 法规 著作
用户名: 密码: 注册 忘记密码?
    创建新词条
科技百科
  • 人气指数: 1863 次
  • 编辑次数: 1 次 历史版本
  • 更新时间: 2009-03-18
admin
admin
发短消息
相关词条
Intel Smart Connect
Intel Smart Connect
THX
THX
电容式触摸屏
电容式触摸屏
USB 3.0
USB 3.0
超速计算机芯片
超速计算机芯片
相变存储技术
相变存储技术
超级计算机模拟图
超级计算机模拟图
笔记本常见接口
笔记本常见接口
UEFI
UEFI
WebP
WebP
推荐词条
希拉里二度竞选
希拉里二度竞选
《互联网百科系列》
《互联网百科系列》
《黑客百科》
《黑客百科》
《网络舆情百科》
《网络舆情百科》
《网络治理百科》
《网络治理百科》
《硅谷百科》
《硅谷百科》
2017年特斯拉
2017年特斯拉
MIT黑客全纪录
MIT黑客全纪录
桑达尔·皮查伊
桑达尔·皮查伊
阿里双十一成交额
阿里双十一成交额
最新词条

热门标签

微博侠 数字营销2011年度总结 政务微博元年 2011微博十大事件 美国十大创业孵化器 盘点美国导师型创业孵化器 盘点导师型创业孵化器 TechStars 智能电视大战前夜 竞争型国企 公益型国企 2011央视经济年度人物 Rhianna Pratchett 莱恩娜·普莱契 Zynga与Facebook关系 Zynga盈利危机 2010年手机社交游戏行业分析报告 游戏奖励 主流手机游戏公司运营表现 主流手机游戏公司运营对比数据 创建游戏原型 正反馈现象 易用性设计增强游戏体验 易用性设计 《The Sims Social》社交亮 心理生理学与游戏 Kixeye Storm8 Storm8公司 女性玩家营销策略 休闲游戏的创新性 游戏运营的数据分析 社交游戏分析学常见术语 游戏运营数据解析 iPad风行美国校园 iPad终结传统教科书 游戏平衡性 成长类型及情感元素 鸿蒙国际 云骗钱 2011年政务微博报告 《2011年政务微博报告》 方正产业图谱 方正改制考 通信企业属公益型国企 善用玩家作弊行为 手机游戏传播 每用户平均收入 ARPU值 ARPU 游戏授权三面观 游戏设计所运用的化学原理 iOS应用人性化界面设计原则 硬核游戏 硬核社交游戏 生物测量法研究玩家 全球移动用户 用户研究三部曲 Tagged转型故事 Tagged Instagram火爆的3大原因 全球第四大社交网络Badoo Badoo 2011年最迅猛的20大创业公司 病毒式传播功能支持的游戏设计 病毒式传播功能 美国社交游戏虚拟商品收益 Flipboard改变阅读 盘点10大最难iPhone游戏 移动应用设计7大主流趋势 成功的设计文件十个要点 游戏设计文件 应用内置付费功能 内置付费功能 IAP功能 IAP IAP模式 游戏易用性测试 生理心理游戏评估 游戏化游戏 全美社交游戏规模 美国社交游戏市场 全球平板电脑出货量 Facebook虚拟商品收益 Facebook全球广告营收 Facebook广告营收 失败游戏设计的数宗罪名 休闲游戏设计要点 玩游戏可提高认知能力 玩游戏与认知能力 全球游戏广告 独立开发者提高工作效率的100个要点 Facebook亚洲用户 免费游戏的10种创收模式 人类大脑可下载 2012年最值得期待的20位硅谷企业家 做空中概股的幕后黑手 做空中概股幕后黑手 苹果2013营收 Playfish社交游戏架构

并发程序设计 发表评论(0) 编辑词条

目录

并发程序设计编辑本段回目录

 

正文编辑本段回目录

  由若干个可同时执行的程序模块组成程序的程序设计方法。这种可同时执行的程序模块称为进程。进程由数据和有关的语句序列组成。组成一个程序的多个进程可以同时在多台处理器上并行执行,也可以在一台处理器上夹插执行。采用并发程序设计可以使外围设备和处理器并行工作,缩短程序执行时间,提高计算机系统的效率。例如,在一个单处理器系统中,从磁盘读入数据经加工后打印输出,不采用并发程序设计时,解决这个问题的程序是循环地执行读入一批数据,然后,加工打印输出。执行这个程序时,磁盘机、处理器和打印机顺序执行输入、加工和输出操作。虽然计算机的外围设备和处理器可以并行操作,但执行上述程序时它们只能串行工作。如果采用并发程序设计,解决上述问题的程序由以下两个进程组成。①读盘进程:循环地执行读入一批数据,加工后送入输出缓冲区;②打印进程:循环地执行从缓冲区取出数据打印输出。在打印进程执行打印输出时只需要打印机,而不需要磁盘机和处理器。因此,在打印进程启动打印机后,在打印机输出的过程中可以启动读盘进程输入和加工数据。执行这个程序时,处理器、磁盘机和打印机并行工作,能缩短程序执行的时间,提高计算机系统的效率。
  发展过程 60年代初期出现的多道程序设计是并发程序设计的萌芽。在一个多道程序设计系统中,一个计算机系统可以同时接受多个用户程序,并让它们交替占用处理器运行。当一道程序因为等待外围设备而暂时不能运行时,就启动另一道程序运行,而各道程序之间没有关系。因此,多道程序设计能提高计算机系统的效率,但并不能缩短一道程序的执行时间。在出现多道程序设计时,人们尚不清楚并发这个概念和由此产生的如死锁等问题。60年代初期出现的许多多道程序设计系统,根本没有考虑死锁问题。因此,这些系统都有不同程度的错误和隐患。1968年,E.W.代克斯特拉设计的操作系统T.H.E.,首次系统地表明了并发程序设计的概念和有关问题。他注意到并发进程访问公共变量的问题,提出用PV操作解决公共变量问题。此外,他还采用层次结构方法防止死锁。然而,T.H.E.系统是用汇编语言编写的。到70年代,人们才开始将并发程序设计的概念引入程序设计语言中,先后出现并发PASCAL、MODULA-II和ADA等程序设计语言。与此同时,还开展了防止死锁、死锁检测和同步机制的研究,提出银行算法、按序分配等防止死锁的算法和管程等同步机制。到80年代,并发程序设计的研究已逐渐完善,应用也日益广泛。
  基本内容 并发程序设计的主要研究内容有:同步机制、死锁的预防和检测,以及并发程序设计语言。
  同步  在并发程序设计中,将加工后的数据送入缓冲区和从缓冲区取出数据打印输出必须依次进行。在数据送入缓冲区前不能打印输出,在缓冲区内的数据没有打印输出完毕时不能输入;否则,一批数据可能被重复打印或者一批数据还没有打印输出就被新送入的数据冲掉。因此,对“送入缓冲区”和“从缓冲区取出数据”两个操作必须加以约制,以保证它们依次执行,否则就会发生错误。
  产生这个问题的原因是两个进程都要访问缓冲区,也就是说它们有一个公共变量。在并发程序设计中,各进程对公共变量的访问必须加以约制,这种约制称为同步。进程的同步是通过同步机制实现的。现已有多种同步机制,具有代表性的是PV操作和管程。
  PV操作是最早提出的同步操作。PV操作的名称来源于荷兰字prolagen(企图降低)和verhogen(升起)。PV操作是作用于信号量上的原语。所谓原语是指其执行是不会被打断的,即一个进程在执行PV操作时,不会强行地被打断而让处理器去执行另一个进程。PV操作的定义是:执行P操作P(S)时,信号量S之值减1,若结果不为负数,见P(S)执行完毕;否则,执行P操作的进程暂时停止。等待释放。执行V操作V(S)时,信号量S之值加1,若结果不大于 0,则释放一个等待释放的进程。有了PV操作后,上例中的问题就即可解决。
  1973年,C.A.R.霍尔提出的管程是另一种重要的同步机制。管程是指一组公共数据同与其有关的操作的集合。只有引用管程中的操作才能访问管程中的数据。一个进程引用管程中的操作时,只有在管程中的各操作均不处于活动状态时才被响应。当管程中的一个操作被引用后,它就成为活动状态。当管程中一个操作已执行完毕或在执行中处于等待状态时,它就不是活动状态。管程将公共数据同与其有关的操作集中在一起,使得并发程序设计易于理解,程序正确性也容易保证。因此,管程有助于同步机制从PV操作向前发展。它是并发程序设计趋于成熟的标志之一。
  死锁  进程因争夺资源而无休止地相互等待称为死锁。例如,进程P1占有了绘图机而申请行式打印机,进程P2占有了行式打印机而申请绘图机。它们都因为申请不到资源而永远等待,这就是死锁。解决死锁问题有两种途径:一是预防死锁,设计各种资源调度算法,防止死锁发生;另一种途径是检测死锁,当死锁发生时能及时发现并进行排除。
  语言  要有效地采用并发程序设计,必须提供并发程序设计语言。并发程序设计语言的主要特征,是引入了进程概念。因此,用它编写的程序包含若干可同时执行的进程。此外,并发程序设计语言还提供实现进程同步和通信的手段。
  参考书目
 P.B.汉森著,杨芙清等编译:《并发程序的系统结构》,国防工业出版社,北京,1982。(Per Brinch Hansen,The Architecture of Concurrent Programs, Prentice Hall,Englewood Cliffs,New Jersey,1977.

 

配图编辑本段回目录

 

相关连接编辑本段回目录

→如果您认为本词条还有待完善,请 编辑词条

词条内容仅供参考,如果您需要解决具体问题
(尤其在法律、医学等领域),建议您咨询相关领域专业人士。
0

标签: 并发程序设计

收藏到: Favorites  

同义词: 暂无同义词

关于本词条的评论 (共0条)发表评论>>

对词条发表评论

评论长度最大为200个字符。