- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
                        查看更多
                        
                    
                
 下载 
                       第8章 可 移 植 性 
       最后,标准化与常规相仿,能成为强有力秩序的另一种具体化形式。但是它又 
    与常规不同,它已经被现代建筑学公认为是我们技术的浓缩产物,因此以其潜在的 
    支配地位和蛮横特征而令人恐惧。 
                                       Robert Ve n t u r i ,《建筑学中的复杂和矛盾》 
    写出能够正确而有效地运行的软件是很困难的。因此,如果某个程序能在一个环境里工 
作,当你需要把它移到另一个编译系统,或者处理器,或者操作系统上时,不会希望再重复 
做太多原来已经做过的工作。最理想的情况是什么都不用改。 
    这种理想就是程序的可移植性。实际上,“可移植性”常被用来指一个更弱的概念,其意 
思是说,与凭空写出这个程序相比,对它做些修改挪到另一个地方将更容易一些。这种修改 
越容易做,我们就说这个程序的可移植性越强。 
    你可能会奇怪,为什么我们还要为可移植性费心呢?如果软件都是准备在某些特定条件 
下,在一个特定环境里运行的,为什么还要在使它具有更广泛的可接受性方面白费精力呢? 
首先,任何成功的程序,几乎总是注定要被以原来不曾预料的方式,用到从未想到的地方去。 
把一个软件构造得比它的规范更一般些,结果就会是以后的更少维护和更好使用。第二,环 
境总是在变。当编译系统、操作系统或者硬件升级的时候,其特性可能就不同了。程序对特 
殊特征的依赖越少,它也就越少可能崩溃,也越容易适应改变以后的环境。最后,也是最重 
要的,可移植的程序总是更优秀的程序。为把程序构造得更具有可移植性的努力也会使它具 
有更好的设计,更好的结构,经过更彻底的测试。一般地说,可移植程序设计的技术与优良 
程序设计的技术是密切相关的。 
    当然,可移植性的程度也应当根据现实来考虑。不存在什么绝对的可移植程序,只有那种 
已经在足够多的环境里试验过的程序。但是,我们仍然可以把可移植性作为一个目标,力图 
去开发那种几乎不用修改就能够运行在任何环境上的软件。甚至当这个目的不能完全达到时, 
在程序构造过程中花在可移植性上的功夫也将会得到回报,例如在这个软件需要升级的时候。 
    我们的看法是:应该设法写这样的软件,它能工作在它必须活动于其中的各种标准、界 
面和环境的交集里。不要为纠正每个移植性问题写一段特殊代码,正相反,应该修改这个软 
件本身,使它能够在新增加的限制下工作。利用抽象和封装机制限制和控制那些无法避免的 
不可移植代码。通过将软件维持在各种限制的交集里面,局部化它的系统依赖性,这样你的 
代码在被移植后仍将更加清晰、更具通用性。 
8.1  语言 
盯紧标准。得到可移植代码的第一步当然是使用某种高级语言,应该按照语言标准 (如果有的 
话)去写程序。二进制不可能很容易地移植,但是源代码可以。当然,即使这样做也还会有问 
  150计计程序设计实践 
                                                                      下载 
题,在编译系统如何将源程序翻译到机器指令的方式方面,也可能有些东西没有精确定义, 
对标准语言也是如此。广泛使用的语言只存在一个实现的情况是罕见的,通常都有多个编译 
系统提供商,对于不同操作系统,又有不同的版本,还有随着年月更替而不断出现的不同发 
行版本。它们对你的源代码可能做出不同解释。 
    为什么语言标准不是一个严格定义呢?有时标准是不完全的,对某些特性之间的相互作 
用没有给出定义。有时标准会有意地不对某些东西做出定义,例如, C和C++                             语言里的 c h a r 
类型可以是有符号的或是无符号的,而且不必正好是 8位。把这些事项留给写编译系统的人去 
解决,有可能产生出更有效的实现,或者避免语言对它能在其上运行的硬件提出太多限制。 
当然,这种做法可能给程序员带来困难。政治上和技术上的相容性问题也可能导致某种妥协, 
使标准对某些细节不做具体定义。最后,语言都是极端复杂的,编译系统也很复杂,理解中 
可能出错,实现里面也可能有毛病。 
    有时语言根本没有经过标准化。 C语言正式的A N S I / I S O标准在 1 9 8 8年颁布,而I S O 的C + + 
的标准直到 1 9 9 8年才被批准,在我们写这些的时候,还没有一个在用的编译系统支持这个正 
式标准。J a v a 是更新一些的语言,与标准化的距离还有许多年。一个语言标准的开发通常总 
是要等到这个语言已经有了许多不同的、互相冲
                您可能关注的文档
最近下载
- 辽2002SJ802-2 厨房、卫生间垂直集中式排烟气系统.docx VIP
- 新闻摄影培训课件.pptx VIP
- 肾造瘘管相关知识.pptx
- 现场验收检查原始记录填写要求:(GB50300-2013附表及填写范例完整75组数据或描述).pdf VIP
- 2025年70岁以上老人考驾驶证三力测试题.pdf VIP
- 护理学基础各种注射法.pptx VIP
- 西游记中的乘法口诀(教学设计)-2024-2025学年二年级上册数学北师大版.docx VIP
- 护理事业十五五发展规划(2026-2030).docx
- 护理事业十五五(2026-2030)发展规划纲要.docx
- 青海省2025年中考语文真题试卷附同步解析答案.docx VIP
 原创力文档
原创力文档 
                        

文档评论(0)