`
shinfocom
  • 浏览: 1242367 次
文章分类
社区版块
存档分类
最新评论

软件开发还远不是一种“科学” .

 
阅读更多

很多大学里是把软件开发相关的专业划入工科的,这给人一种错觉,让人认为软件开发也是一个工程学科,就像土木建筑,动力机械那样。

但这从根本上错了,土木建筑,动力机械的背后有确实的科学定律作为支撑,而软件开发的背后基本上什么都没有,远不是一种“科学”。

也正因此,“软件工程”的现实意义也就远不如“土木工程”,“动力工程”。

 

每个人对“科学”的定义可能不同,但在这里,我们可以做一个简化版的定义:

当有一组在限定条件下颠扑不破的定律做支撑时,相应的知识,我们可以称之为科学,科学自身可以体现为一种确定性。

比如说:牛顿的力学定律在低速时是不容违反的,是一种铁则,那基于此的各种知识就可以成为科学。

 

从这个视角出发,我们会发现,在软件的世界里,压根找不到属于软件的“牛顿力学定律”,有的只是杂多、纷争和不确定性。

 

面向对象应该是接受程度最高的分析和设计方法,但即使如此Eric RaymondLinus也仍然会站出来批判它。

参见:

Eric Raymond谈模块化原则,胶合层和面向对象的缺陷 孟岩译

http://blog.csdn.net/myan/article/details/1924 

C++一无是处

http://news.csdn.net/a/20100612/218785.html 

简单来讲:Eric Raymond认为OO会导致过度分层,Linus认为面向对象解决的是一些小问题,他们不约而同的反对OO

你能找到如此批判牛顿定律的人么?

 

Eric Raymond他们的观点又不由得你不重视,除非你认为Eric RaymondLinus信口雌黄或人品有问题,否则你可以批判,可以不同意,但你不能忽视他们的声音。

他们的声音必然基于他们的经历,代表着特定的现实,而现实本身代表合理性。

 

面向对象之外,各种观点想法就更多,这导致了软件的世界是杂多的,不确定的,行业中人大多都为名词所苦。

随便看一下吧,有多少人可以精确分辨这些词间的差异:

框架(Framework),架构(Architecture),面向对象分析和设计(Object Oriented Analysis and Design),设计模式(Design Pattern),契约式编程(Design by Contract),测试驱动开发(Test Driven Development),面向方面的编程(Aspect Oriented Programming),模型驱动架构(Model Driven Architecture),基于组件的开发(Component-Based Development),敏捷软件开发(Agile Software Development),元编程(Meta programming),面向服务的体系结构(Service-oriented architecture),Feature-oriented programming... ...(编程语言就更不要说了,实在不知道有多少个,但反过来想,世界上真需要这么多种语言么?)


这些不同的方法(概念或语言)只要存在,即使彼此有冲突,也必然有其合理之根基,这里无意分析其优劣,

只是想说:软件开发的定论在那里?我们究竟又该根据什么来判定那个是适合的,那个是不适合的?这种众说纷纭,真是工程学科应该有的状况么?

如果所有这一切都只能归还给当事人,那就必然纷争不断,软件开发也就一定不是一种科学。

 

在这样一种情景下,由于任何人都可能是错的,务实的程序员也就必须选择相信自己多过相信别人,那怕别人有天大的来头。

相信自己基于事实和逻辑的分析,即使错了,也可以成为一种进步的养分;相信别人,错了不会进步,对了也是别人对了,有什么意思。

狂妄的程序员则可以挑战“牛顿”这一角色。

 

杨昌济先生,曾经说过两句话,特别有意思,也契合软件开发的情景,因此把它放在这里,作为结尾:

横尽虚空,山河大地无一可恃,而可恃唯我。

竖尽来劫,前古后今无一可据,可据者唯有当前。

0
0
分享到:
评论

相关推荐

    信息化项目软件开发的费用测算规范方案.pdf

    信息化项目软件开发费用测算...本标准规定了信息化项目软件开发费用测算的方法及过程,包括软件开发费用的构成、软件规模、工作量、费用及工期测算方法及过程,为软件开发项目的成本估算和时间表提供了一个科学的方法。

    软件开发的哲学思考.pdf

    1. **心智活动**:文章开篇便指出,软件开发本质上是一种基于人类心智活动的过程。这一观点强调了软件开发不仅仅是技术层面的问题,更是心理学、认知科学等领域交叉的结果。 2. **人性的反映**:软件开发不仅反映了...

    用科学的思维方法指导软件的设计开发

    面向对象编程(Object-Oriented Programming, OOP)是现代软件开发中最常用的一种编程范式。其核心思想包括封装、继承、多态等特性,能够有效地降低程序复杂度并提高代码复用率。 - **封装**:将数据和操作这些数据...

    《数据结构》课程远程教学软件的开发.pdf

    数据结构是关于如何存储、管理和操作数据的科学,它对于编程、软件开发和数据库设计至关重要。 5. 计算机软件技术 - 文档提到了包括Microsoft SQL Server、Windows NT Server等在内的软件技术。这些技术是开发和...

    软件开发案例分析.ppt

    首先,软件工程的产生背景源于20世纪60年代末至70年代初的“软件危机”,当时软件开发面临成本超支、进度延误和质量问题,因此人们开始寻求一种系统化、规范化的软件生产方式,从而诞生了软件工程这一学科。...

    行业分类-物理装置-一种软件开发的高效鼠标.zip

    标题中的“行业分类-物理装置-一种软件开发的高效鼠标”揭示了这个压缩包内容的三个关键信息点:首先,它属于行业分类,这可能指的是技术、计算机科学或软件工程领域;其次,它涉及到物理装置,暗示我们可能会讨论...

    软件开发费用计算

    在软件开发过程中,计算费用是一项重要的任务,它涉及到项目的预算制定和成本控制。...功能点分析法提供了一种相对客观和科学的方法,但还需要灵活运用和适时调整,以确保计算结果的准确性和合理性。

    电子政务-一种适用于计算机软件开发的笔记本电脑桌.zip

    电子政务,全称为Electronic Government,是指政府机构利用信息技术和网络技术进行政务活动的一种方式,旨在提高政府服务效率,促进信息共享,实现政府决策科学化、公共服务便捷化。在这个压缩包中,我们关注的是...

    软件工程题库-多选.doc

    2. 需求分析是软件开发的第一个关键阶段,它定义了软件必须完成的任务和预期的功能,不属于软件开发后期的阶段如总体设计、详细设计或编码与测试。 3. 测试是保证软件质量的关键环节,通过设计和执行测试用例来检查...

    第1章软件开发方法软件工程.ppt

    软件工程这一概念由Michael Jackson提出,它不仅仅是一个描述规范,更是一种通过运用现代科学技术来设计和构建计算机程序及其相关文档的体系。 著名软件工程专家Barry W. Boehm将软件工程定义为运用现代科学技术...

    第1章软件开发方法(二)软件工程.pptx

    IEEE在1983年给出的软件工程定义进一步扩展了这一概念,将软件工程定义为一种系统性的方法,旨在以高效、高质量和经济的方式进行软件的生命周期管理,包括软件开发、运行和退役,涵盖了程序、方法、规则、文档和运行...

    软件开发的科学和艺术之软件测试

    ### 软件开发的科学和艺术之软件测试 #### 微软的测试人员分类及其作用 在软件开发过程中,软件测试是一项至关重要的环节。它不仅确保了软件的质量,还能帮助开发者及时发现问题并进行修正。根据《软件开发的科学...

    第章软件开发方法软件工程.pptx

    软件工程是一门综合性的学科,它结合了计算机科学、管理科学、工程学和数学等多个领域的知识,旨在解决软件开发过程中的复杂性和挑战。软件工程的基本概念是通过系统化、规范化的方法来设计、构建、测试和维护软件,...

    软件开发基础1-3

    1. **编程语言基础**:软件开发的核心是编程,掌握至少一种或多种编程语言是必要的。例如,Java是一种广泛使用的面向对象的语言,适用于企业级应用;Python则以其简洁易读的语法和强大的科学计算库深受数据科学家和...

    软件开发工具 复习笔记.pdf

    4. 第四代语言(4GL)与软件开发工具的关系在于,4GL是软件开发工具的一种,它简化了编程过程,让开发者可以更专注于业务逻辑,而不是语法细节。然而,软件开发工具除了4GL的功能外,还包含更多如需求分析、设计支持...

    软件项目开发的文档(全套).zip

    在当今的信息时代,软件项目的开发已经成为了推动社会进步和企业发展的重要力量。然而,软件项目的成功不仅仅是...通过科学严谨的项目文档管理,软件开发项目将能够更加顺利地推进,最终产出高质量、高效率的软件产品。

    软件开发费用计算方法最新版本.doc

    通过以上详细步骤和方法,软件开发团队和管理者能够更科学、精确地估计项目费用,从而制定合理的项目预算,确保项目的顺利进行。这些方法的应用不仅可以降低项目风险,还有助于提升项目管理的专业性和透明度。在实际...

    嵌入式软件开发技术习题集.doc

    嵌入式软件开发技术习题集是计算机科学和技术领域中的一个重要方向,这个习题集涵盖了嵌入式软件开发的基本概念、嵌入式处理器、嵌入式操作系统、嵌入式软件开发技术等多方面的知识。 1. 嵌入式软件开发的基本概念...

    2022年自学考试软件开发工具试题.doc

    2. **软件工具的历史**:软件工具的思想和应用在20世纪60年代得到广泛宣传,随着计算机科学的发展,它们逐渐成为提高软件开发效率的关键因素。 3. **软件开发过程**:在软件开发中,顾客界面是直接与变更规定相关的...

Global site tag (gtag.js) - Google Analytics