热门标签 | 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,欢迎访问原出处。


推荐阅读
  • 本文介绍了一种处理AJAX操作授权过期的全局方式,以解决Asp.net MVC中Session过期异常的问题。同时还介绍了基于WebImage的图片上传工具类。详细内容请参考链接:https://www.cnblogs.com/starluck/p/8284949.html ... [详细]
  • 本文是一位90后程序员分享的职业发展经验,从年薪3w到30w的薪资增长过程。文章回顾了自己的青春时光,包括与朋友一起玩DOTA的回忆,并附上了一段纪念DOTA青春的视频链接。作者还提到了一些与程序员相关的名词和团队,如Pis、蛛丝马迹、B神、LGD、EHOME等。通过分享自己的经验,作者希望能够给其他程序员提供一些职业发展的思路和启示。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 本文介绍了2019年上半年内蒙古计算机软考考试的报名通知和考试时间。考试报名时间为3月1日至3月23日,考试时间为2019年5月25日。考试分为高级、中级和初级三个级别,涵盖了多个专业资格。报名采取网上报名和网上缴费的方式进行,报考人员可登录内蒙古人事考试信息网进行报名。详细内容请点击查看。 ... [详细]
  • 拥抱Android Design Support Library新变化(导航视图、悬浮ActionBar)
    转载请注明明桑AndroidAndroid5.0Loollipop作为Android最重要的版本之一,为我们带来了全新的界面风格和设计语言。看起来很受欢迎࿰ ... [详细]
  • 从零学Java(10)之方法详解,喷打野你真的没我6!
    本文介绍了从零学Java系列中的第10篇文章,详解了Java中的方法。同时讨论了打野过程中喷打野的影响,以及金色打野刀对经济的增加和线上队友经济的影响。指出喷打野会导致线上经济的消减和影响队伍的团结。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • 本文介绍了程序员最美的情人节礼物,即使用JS渲染的3D玫瑰,通过在QQ空间和人人网上分享这个特殊的礼物,可以给情人带来惊喜和喜悦。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • 本文介绍了在Mac上安装Xamarin并使用Windows上的VS开发iOS app的方法,包括所需的安装环境和软件,以及使用Xamarin.iOS进行开发的步骤。通过这种方法,即使没有Mac或者安装苹果系统,程序员们也能轻松开发iOS app。 ... [详细]
  • 如何在跨函数中使用内存?
    本文介绍了在跨函数中使用内存的方法,包括使用指针变量、动态分配内存和静态分配内存的区别。通过示例代码说明了如何正确地在不同函数中使用内存,并提醒程序员在使用动态分配内存时要手动释放内存,以防止内存泄漏。 ... [详细]
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社区 版权所有