您所在的位置:开发 > 架构&设计 > 多核处理器趋势对软件架构的影响

多核处理器趋势对软件架构的影响

2007-09-28 11:16 Mark Figley译者 曹云飞 infoq 我要评论(0) 字号:T | T
一键收藏,随时查看,分享好友!

“Java开发者”的一篇文章中提到,当我们在多核处理器架构这条路上高歌猛进的时候,单线程性能的提升即将在一至三年内迅速减缓。在某些情况下,单线程性能甚至会降低。这便要求软件开发者改变开发软件的方式,进一步利用并行处理架构。

AD:

“Java开发者”杂志上刊载了一篇精彩的文章,作者在文中讲述了软件开发者将会受到业内日益趋向多核处理器与大量并行处理器这股潮流的影响。以下是来自原文的内容:

“作为软件开发者,我们在处理器技术所带来的性能持续增长潮流里乐在其中。实际上,在过去的20年中,处理器的性能几乎以每两年翻倍的速度持续增长着。如果 这样的性能提升突然戏剧性的减缓甚至停滞了,这个世界将会变成什么样子?我们还能继续搭建更大、更重和功能丰富的软件吗?……事实是——单线程性能的提升即将在一至三年内大规模减速。在某些情况下,单线程性能甚至会降低。长期持续不变的攀升会戏剧性的变缓。”

尽管杂志的名字很专业化,但即使你不是一个Java工程师,这篇文章本身也是很值得一读的。你也许能猜到,作者并不会只让你感到上述段落所带来的失望。文章将解释我们将需要怎样做,来使我们的软件架构去适应持续不变的性能提升。

“……业内已经开始关注为延续性能提升潮流所进行的多核、多线程处理器的设计。这些设计所关注的不是执行单个线程的性能提升,而是多个,有时甚至是巨量线程数的并行运行……作为一个开发人员而言,学习如何开发可以在数量持续增长的并行处理器上面高效运行的应用程序就变得很重要了。由于单线程的性能提升不会象 过去那么快,开发人员将会不得不关注并发来提高某个给定任务的性能。”

文章接下来给出了一个关于并行编程策略的概述,以Amdahl法则开始:

“当你开始并行编程时,所熟悉的第一条准则是Amdahl法则。Amdahl法则说,限制你的程序加速运行的将是程序中不能并行执行的部分。比如说,如果性能监控显示,程序中那些只能在一个处理器上串行执行的代码需要花费20%的运行时间,那么即使余下的代码都做了最佳并行化,也不管你扔给它多少处理器,你最多也只能获得5倍的速度提升。负载不平衡是一个类似的问题。如果你将你的代码分成N个子任务,执行它们所需的时间不是1/N。所需的时间是执行子任务所 需时间的最大值。”

文章之后讲述了并发问题和线程的设计,特别是在并行程序设计方面的Java语言模型。全文以宣布了一个由IBM开发的称为X10的新语言收尾。该语言 为Java语言添加加了更高层次的模型,尤其是并行应用开发方面。它通过提供管理并行操作的简化语义和与这些操作相关的数据分布,试图简化并发设计。

X10并不是一个真正的内部领域专用语言(DSL),因为它的语法不符合Java的语法。它使用Java语言作为基础并由此构造了一个新的、严格的语言,从这一点上来看和AspectJ(之前的5.0版本)很相似。

查看英文原文The Software Architecture Impact of the Multi-Core Processor Trend

【责任编辑:dizzarz TEL:(010)68476606】

网友评论TOP5

查看所有评论(

提交评论

  1. 编程排行榜:图形编程的LOGO语言
  2. 什么是响应式Web设计?

热点专题

更多>>

读书

Expert C# 2005 Business Objects中文版
本书描述了怎样应用面向对象的概念来进行.NET应用程序的架构、设计和开发。作者将重点放在了面向业务的对象,即业务对象和怎样在

51CTO旗下网站

领先的IT技术网站 51CTO 领先的中文存储媒体 WatchStor 中国首个CIO网站 CIOage 中国首家数字医疗网站 HC3i 移动互联网生活门户 灵客风LinkPhone