个人阅读&个人总结
个人阅读作业+总结
助教推荐的那些文章都是软件工程上的经典文章,阅读后感受到软件工程本身的深度,之前学习的软件工程都只是皮毛之中的皮毛而已。随着软件规模的越来越庞大,软件工程已经成为了软件开发中的必备知识。在软件工程中有很多前人的思考和经历在其中,细细品读下来还是十分有趣、有用的。
No Silver Bullet - Essence and Accidents of Software Engineering - Brooks
所有的软件在构建过程中都会遇到根本性的任务:组成抽象软件实体的复杂概念,防不胜防的意外以及在一定的时间和空间限制下,从抽象的软件概念到具体的编程语言乃至机器语言的编码过程。作者提到几乎大部分高效的软件生产性的获得需要人为的想一些方法将意外的任务尽可能减少。他将软件比喻成西方神话中可怕的狼人,将一劳永逸的解决方案比喻成为唯一对狼人有效的银弹,并在文中叙述软件工程中并没有这样的一个“银弹”,能让人高效管理软件工程而不出半点差错。但他也提出了一些方法,虽然不能达到“银弹”的级别,但多多少少对软件的管理有较大的帮助:
- 积极探索巨大的市场以避免重新制造可以买到的轮子;
- 将快速的原型作为迭代计划中的一部分来满足软件的要求;
- 增量开发,对于软件的新功能、测试等等需求做增量开发,向系统中添加新的过程和函数。
- 物尽其用,善用人才。
big ball of mud
虽然高度关注高级软件架构模式,但事实上标准的软件架构实际上很少被讨论。一个大球泥是一个随便的,即使是随意的,结构化的系统。在实际开发中,我们往往为了追求更多的功能不加设计的添加代码使得软件整个结构越来越臃肿最终导致成为一个完美的大泥球,使得在上面开发或者维护的成本极其高,任谁也不想也不能在上面进行有效的开发。
- 大教堂模型中,每个软件版本都提供了源代码,但在两个发行版之间开发的代码仅限于一组独立的软件开发人员。以GNU Emacs和GCC为例。
- 集市模型,在该代码开发了互联网鉴于公众。Raymond 称Linux内核项目的领导者Linus Torvalds是这个过程的发明者。雷蒙德还提供了他自己实现这个模型的Fetchmail项目的传闻。
在我们的开发中,目前使用的开发过程更合适的模型描述是大教堂模型。开发软件过程中并没有使用互联网进行“集市”一般的开发,一般都是自己或者几个人固定进行开发。
Worse?Better?
有了正确的事情,设计师同样关心简单性,正确性,一致性和完整性。随着越来越好,设计人员几乎完全关注实现的简单性和性能,并且只在正确性,一致性和完整性方面工作,只是为了完成工作,为了简单起见而牺牲了其他任何品质。然而,这个论点是,使用越差越好的程序设计和实现的程序可以比正确的版本更快地写出来,可以运行在更广泛的计算机上,容易携带,如果足够好,将被接受得更快,最终将得到改善,并且一般来说,比右派方案表现出更好的生存特征。更糟糕的是程序就像病毒一样迅速传播,很快普及。随着时间的推移,如果他们成功了,
他们会得到改善。
具体来想我认为作者提出的更加糟糕的软件指的就是软件首先不论质量怎样需要尽可能快速的实现需求并发布,并进行快速的迭代更新以达到最后的好的质量。这样可以在市场上占有先机更容易获得成功。而正确的就进入市场晚可能获取成功需要的努力就更大。
敏捷!
- 敏捷方法是适应性的而不是预测性的。 工程方法倾向于在很长一段时间内详细规划软件过程的大部分内容,直到事情发生变化,这种方法运行良好。 所以他们的本性就是抵制变化。 敏捷方法,但是,欢迎改变。 他们试图成为适应和改变的过程,甚至改变自己。
- 敏捷方法是以人为本而不是以过程为导向的。 工程方法的目标是定义一个恰当地使用它的流程。 敏捷方法断言,没有一个过程能够弥补开发团队的技能,所以一个过程的作用是支持开发团队的工作。
我们在实际开发过程中其实使用到了敏捷的一些思想,比如快速迭代,在每一轮迭代之间收集用户反馈以达到一个方向的修正;是事情驱动的,刚开始做完初步的设计后随着事情的变化快速修改设计并再开发。
个人阅读&个人总结的更多相关文章
- 【原】FMDB源码阅读(三)
[原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...
- 【原】FMDB源码阅读(二)
[原]FMDB源码阅读(二) 本文转载请注明出处 -- polobymulberry-博客园 1. 前言 上一篇只是简单地过了一下FMDB一个简单例子的基本流程,并没有涉及到FMDB的所有方方面面,比 ...
- 【原】FMDB源码阅读(一)
[原]FMDB源码阅读(一) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 说实话,之前的SDWebImage和AFNetworking这两个组件我还是使用过的,但是对于 ...
- 【原】AFNetworking源码阅读(六)
[原]AFNetworking源码阅读(六) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这一篇的想讲的,一个就是分析一下AFSecurityPolicy文件,看看AF ...
- 【原】AFNetworking源码阅读(五)
[原]AFNetworking源码阅读(五) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇中提及到了Multipart Request的构建方法- [AFHTTP ...
- 【原】AFNetworking源码阅读(四)
[原]AFNetworking源码阅读(四) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇还遗留了很多问题,包括AFURLSessionManagerTaskDe ...
- 【原】AFNetworking源码阅读(三)
[原]AFNetworking源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇的话,主要是讲了如何通过构建一个request来生成一个data tas ...
- 【原】AFNetworking源码阅读(二)
[原]AFNetworking源码阅读(二) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇中我们在iOS Example代码中提到了AFHTTPSessionMa ...
- 【原】AFNetworking源码阅读(一)
[原]AFNetworking源码阅读(一) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 AFNetworking版本:3.0.4 由于我平常并没有经常使用AFNetw ...
- [PHP源码阅读]count函数
在PHP编程中,在遍历数组的时候经常需要先计算数组的长度作为循环结束的判断条件,而在PHP里面对数组的操作是很频繁的,因此count也算是一个常用函数,下面研究一下count函数的具体实现. 我在gi ...
随机推荐
- 20155211课下测试ch10补交
20155211课下测试ch10补交 1.假设下面代码中的foobar.txt中有6个ASCII字母,程序的输出是() A.c = f B.c = o C.c = b D.c = 随机数 答案:A 解 ...
- 2017-2018-2 20155315《网络对抗技术》Exp2:后门原理与实践
实验目的 学习建立一个后门连接. 教程 实验内容 使用netcat获取主机操作Shell,cron启动. 使用socat获取主机操作Shell, 任务计划启动. 使用MSF meterpreter(或 ...
- 19-[模块]-xml
1.xml协议 xml是实现不同语言或程序之间进行数据交换的协议,跟json差不多,但json使用起来更简单,不过,古时候,在json还没诞生的黑暗年代,大家只能选择用xml呀,至今很多传统公司如金融 ...
- 15-[mysql内置功能]--函数,流程控制 (未完成)
1.MySQL中提供了许多内置函数 一.数学函数 ROUND(x,y) 返回参数x的四舍五入的有y位小数的值 RAND() 返回0到1内的随机值,可以通过提供一个参数(种子)使RAND()随机数生成器 ...
- tornado-About Web
1.轻量级的web开发框架,没有像django那样的命令行工具,只用于写一些小的脚本 (1)安装tornado包 pip intall tornado # conda install tornado( ...
- matlab GUI工作原理
例如,用GUIDE创建名为ceshi的GUI程序,其m文件的主函数有如下形式.那么,打开该GUI时,它到底是怎么运行的呢?以下略作小结,欢迎大家补充 function varargout = cesh ...
- 【ORACLE】ORACLE RAC设置控制文件多路
[oracle@rac01 ~]$ srvctl stop database -d proc -o immediate [oracle@rac01 ~]$ sqlplus / as sysdba SQ ...
- Assert.notNull(sessionUser);
rg.springframework.util.Assert Assert翻译为中文为"断言".就是断定某一个实际的值就为自己预期想得到的,如果不一样就抛出异常.
- Eclipse web项目更改项目名称
1. 右键工程:Refactor->Rename,更改项目名称: 2. 修改项目目录下:.project文件 <?xml version="1.0" encoding= ...
- appium 元素定位工具
两种元素定位工具: 1.uiautomatorviewer是android-sdk自带的一个元素定位工具,目录D:\androidsdk\androidsdk\tools\bin . 双击启动uiau ...