热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

软件开发还算不上是一门科学

很多大学里是把软件开发相关的专业划入工科的,这给人一种错觉,让人认为软件开发也是一个工程学科,就像土木建筑,动力机械那样。但这从根本上错了,土木建筑,动力机械的背后有确实的科学定律作为支撑,而软件开发的背后基本上什么都没有,远不是一种“科学”。也正因此,“软件工程”的现实意义也就远不如“土木工程”,“动力工程”。

很多大学里是把软件开发相关的专业划入工科的,这给人一种错觉,让人认为软件开发也是一个工程学科,就像土木建筑,动力机械那样。但这从根本上错了,土木建筑,动力机械的背后有确实的科学定律作为支撑,而软件开发的背后基本上什么都没有,远不是一种“科学”。

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

每个人对“科学”的定义可能不同,但在这里,我们可以做一个简化版的定义:当有一组在限定条件下颠扑不破的定律做支撑时,相应的知识,我们可以称之为科学,科学自身可以体现为一种确定性。比如说:牛顿的力学定律在低速时是不容违反的,是一种铁则,那基于此的各种知识就可以成为科学。

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

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

参见:

简单来讲:Eric?Raymond认为OO会导致过度分层,Linus认为面向对象解决的是一些小问题,他们不约而同的反对OO。你能找到如此批判牛顿定律的人么?

但Eric?Raymond他们的观点又不由得你不重视,除非你认为Eric?Raymond和Linus信口雌黄或人品有问题,否则你可以批判,可以不同意,但你不能忽视他们的声音。他们的声音必然基于他们的经历,代表着特定的现实,而现实本身代表合理性。

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

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

  • 框架(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

?编程语言就更不要说了,实在不知道有多少个,但反过来想,世界上真需要这么多种语言么?

这些不同的方法(概念或语言)只要存在,即使彼此有冲突,也必然有其合理之根基,这里无意分析其优劣,只是想说:软件开发的定论在那里?我们究竟又该根据什么来判定那个是适合的,那个是不适合的?这种众说纷纭,真是工程学科应该有的状况么?

如果所有这一切都只能归还给当事人,那就必然纷争不断,软件开发也就一定不是一种科学。在这样一种情景下,由于任何人都可能是错的,务实的程序员也就必须选择相信自己多过相信别人,那怕别人有天大的来头。

相信自己基于事实和逻辑的分析,即使错了,也可以成为一种进步的养分;相信别人,错了不会进步,对了也是别人对了,有什么意思。狂妄的程序员则可以挑战“牛顿”这一角色。

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

  1. 横尽虚空,山河大地无一可恃,而可恃唯我。
  2. 竖尽来劫,前古后今无一可据,可据者唯有当前。

本文地址:http://www.nowamagic.net/librarys/veda/detail/962,欢迎访问原出处。


推荐阅读
  • 探索新一代API文档工具,告别Swagger的繁琐
    对于后端开发者而言,编写和维护API文档既繁琐又不可或缺。本文将介绍一款全新的API文档工具,帮助团队更高效地协作,简化API文档生成流程。 ... [详细]
  • HTML基础入门指南
    本文将深入浅出地介绍HTML的基础知识,包括其定义、开发工具、制定机构、特性、基本标签及更多实用内容。 ... [详细]
  • SpringMVC RestTemplate的几种请求调用(转)
    SpringMVCRestTemplate的几种请求调用(转),Go语言社区,Golang程序员人脉社 ... [详细]
  • Java中的基本数据类型与包装类解析
    本文探讨了Java编程语言中的8种基本数据类型及其对应的包装类。通过分析这些数据类型的特性和使用场景,以及自动拆装箱机制的实现原理,帮助开发者更好地理解和应用这些概念。 ... [详细]
  • 本文提供了多种方法来计算给定年份和月份的起始日和结束日,并进一步探讨了如何根据年、月、周获取特定周的起始日和结束日。 ... [详细]
  • Linux环境下进程间通信:深入解析信号机制
    本文详细探讨了Linux系统中信号的生命周期,从信号生成到处理函数执行完毕的全过程,并介绍了信号编程中的注意事项和常见应用实例。通过分析信号在进程中的注册、注销及处理过程,帮助读者理解如何高效利用信号进行进程间通信。 ... [详细]
  • 2004年春节,作者与父亲讨论了未来的职业规划,并决定尝试创业开设家教培训班。然而,创业过程中的种种困难和挑战最终导致了项目的失败。 ... [详细]
  • 设计模式在软件开发中被广泛应用,但如果不当使用,可能会导致系统复杂性增加。例如,过度添加类可能导致类图难以理解,代码跟踪变得复杂。本文探讨如何在使用设计模式时保持系统的简洁和高效。 ... [详细]
  • Go语言实现经典排序算法:归并排序
    本文介绍如何使用Go语言实现经典的归并排序算法,探讨其原理、代码实现及性能特点。适合Golang开发者和编程爱好者。 ... [详细]
  • 深入理解Java多线程并发处理:基础与实践
    本文探讨了Java中的多线程并发处理机制,从基本概念到实际应用,帮助读者全面理解并掌握多线程编程技巧。通过实例解析和理论阐述,确保初学者也能轻松入门。 ... [详细]
  • 程序员如何优雅应对35岁职业转型?这里有深度解析
    本文探讨了程序员在职业生涯中如何通过不断学习和技能提升,优雅地应对35岁左右的职业转型挑战。我们将深入分析当前热门技术趋势,并提供实用的学习路径。 ... [详细]
  • 程序员版情书:王思聪的编程式告白
    当程序员用代码表达爱意,会产生怎样的化学反应?一起来看看这封充满技术感的情书,网友笑称这才是真爱! ... [详细]
  • docker镜像重启_docker怎么启动镜像dock ... [详细]
  • GoCV入门指南:配置与基础应用
    本文详细介绍了GoCV的安装配置及基本使用方法,包括如何打开摄像头、图片和视频文件。适合Golang开发者快速上手。 ... [详细]
  • 远程过程调用(RPC)是一种允许客户端通过网络请求服务器执行特定功能的技术。它简化了分布式系统的交互,使开发者可以像调用本地函数一样调用远程服务,并获得返回结果。本文将深入探讨RPC的工作原理、发展历程及其在现代技术中的应用。 ... [详细]
author-avatar
用户q4oaa53j5h
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有