[软件合集软件]软件指导:软件最大的追求是什么
【shitiku.jxxyjl.com--软件水平学习指南】
这段时 间,java世界有两件事情值得关注:工业界力推soa;在开源领域,即将推出的spring 2.0将支持非贫血模型,将oo编程推向一个新的阶段。无论soa全新架构推出还是oo的持续发展,他们都追求同一个终极目标:松耦合。
当我们在java波涛汹涌的潮流中奋击时,我们常常会思考?我为什么要这样做?甚至,我们会想松耦合真的那么酷?可维护性真的是软件唯一?也许我们迷失了方向。
我们要好好探究一下,软件的最大追求是什么?
我们的大学计算机教育只是教会我们如何编程?这如同技工学校中教会学员如何使用车床一样,当我们学会了编程,接下来是什么呢?是不是就没有了呢?是不是就是如同车工那样只需日复一日的反复编程呢?
其实,当你在一个系统中持续编程(增加新的东西),这个系统就变得复杂了,你面临最大的挑战是如何整理你自己的产物。
也就是说:大学教育只教会我们如何“增加新的东西”,但是没有教育我们如何“整理这些东西”,而后者是目前软件领域日新月异不断发生的革命的新动力。
下面我们以具体代码来说明“增加新的东西”和“整理这些东西”完全属于不同层次的学问,有些人谈到软件只会想到算法和数据结构,认为这些才是科学,其实这是将软件数学化,软件不只是科学计算的工具,它自身也是一门科学,更象管理学/经济学一样,是科学和艺术的结合。
在最近java(tm) boutique网站上刊登出一篇文章measuring the complexity of oo systems,衡量 oo系统的复杂性,该文对软件复杂性几个著名公理进行了详细阐述,这些公理如果你不进行学习和培训,即使你使用oo语言java等这样工具,还是显示你是 “业余”的。
软件复杂性包括以下部分(引自measuring the complexity of oo systems):
* cyclomatic complexity (圈复杂性)
* response for class (类的响应)
* weighted methods per class (每个类重量方法)
cyclomatic complexity
cyclomatic complexity可以用下面代码来说明:
cyclomatic complexity (cc) = number of decision points 1
其中number of decision points是指一个if else之类的条件判断语句,比如,是下面这个条语句:
public void isvalidsearchcriteria(searchcriteria s){
if(s!=null) {
return true;
}else{
return false;
}
}
cyclomatic complexity 对代码的可测试性和可维护性上有很大影响,正如上例指出,当你要测试isvalidsearchcriteria()方法 ,你必须写三个测试用例来验证它。
如果这个cc值增加,将有更多的判断点(decision points)数量,也就意味着需要花费更多的力量来测试这些方法。详细更多说明可参考measuring the complexity of oo systems一文。
所以,if else 或while 等条件语句是对真正oo的一种伤害(这是非oo公理见thomas mccabe),可以极端地说:一个好的oo 系统几乎在业务逻辑层看不到超出两个以上条件的if else等判断语句,这些条件语句都是可以被gof设计模式的状态模式/策略模式等替代。
当你的java系统中充满了大量的if else语句,虽然你使用很酷的语言工具,但是说明你的思维是传统过程的,需要重新学习和培训。
response for class(rfc)
这是著名的 chidamber and kemerer公理之一。以下面代码来说明:
public class registrationmanager {
public void createregistration(registrationdata regdata){
dataaccessmanager manager = new dataaccessmanager();
auditmanager auditmanager = new auditmanager();
//save the registration
manager.saveregistration(regdata);
//audit the creattion
auditmanager.createauditrecord(regdata);
}
public registration findregistration(string regnumber){
dataaccessmanager manager = new dataaccessmanager();
registration reg = null;
//find the registration
reg = manager.findregsitration(regnumber);
return reg;
}
}
这个类registrationmanager 依赖其他两个类dataaccessmanager 和 auditmanager 。
按照公理公式:
rfc = m r (m = 这个类中方法个数. r = 其他总数)
在上例中,我们统计类响应rfc数目如下:
在registrationmanager中方法数目 = 2
调用了dataaccessmanager的方法数目 = 2
调用了auditmanager的方法数目 = 1
这样:rfc(registrationmanager) = 2 2 1 = 5
当一个类和很多其他类存在依赖时,它就变得复杂甚至难以修改和维护,这样,rfc值越大,表示你的系统味道越坏。
当然,因为oo系统是基于类和方法,不可能开发出一个0值rfc的系统,但是我们追求的目标是一种平衡,当你设计oo系统时,必须时刻注意这些公理,尽量避免类的编码达到一个rfc高值。
我们如果使用现代一些模式:如ioc模式,可以帮助我们方便不费力气地达到这样一个平衡,因此,使用spring/jdon之类框架是降低rfc值的一个捷径。
weighted methods per class
之前几个公理是介绍如何通过类之间交互调用使得软件系统变得异常复杂,一个系统或一个特定的类自身也会变得异常复杂,有很多方法,weighted method per class公理帮助我们量化定义这些情况。
这个公理定义会依据两种情况:一个类实现;不同的实现。
wmc 1 = 一个类中所有方法个数.
wmc 2 = 所有方法的cyclomatic complexities个数.
无论你选择哪一种公式,一个wmc高值显示这个类也许需要被重整成多个类。
这个公式可以帮助你让类保持干净,并且和相关行为意义上更加靠近(cohesive)。
以前面的rfc例子说明:如果你将dataaccessmanager和auditmanager类中的方法都定义到当前registrationmanager类中,你会得到一个wmc高值,这说明这个类需要重整了。
良好的软件设计
前面章节我们反复提到重整(refactoring),它的意思就是:你不但会“增加新的东西”,而且还要学会“整理这些东西”(重整)。
正如儿童玩玩具一样,他可以无师自通很快学会玩一个新东西,但是,当他玩完很多新玩具以后,他就很难学会整理他到处乱丢的玩具。由此可见:学会编程不值得骄傲(可能源自天生),懂得如何整理才是真正的专业程序员。
现在,让我们回到问题的本质,上述列举了软件的复杂性,复杂会导致难于维护和测试,那我们需要整理,那么整理是否可量化一种程度呢?
我们使用“松耦合”这个概念来表示易于维护、易于测试、易于扩展的程度,当然,松耦合值越高,我们系统更易于维护。当前,软件世界的发展,soa、ioc/aop不都是在追求松耦合的最大化吗?
松耦合一个反义词“紧耦合”,从我们学会玩编程这个玩具开始起,我们就面临两种选择:一种朴素的、无需训练的、近似自然的“紧耦合”路线;一种是经过科学培训的“松耦合”道路。选择哪一条道路就取决于你是否受过专业训练了。
所以,对于编程这个玩具,不在于你是否会玩,而在于你怎么玩?玩的水平。如果不明白这个道理,中国软件的萧条永远不会结束。
这段时 间,java世界有两件事情值得关注:工业界力推soa;在开源领域,即将推出的spring 2.0将支持非贫血模型,将oo编程推向一个新的阶段。
无论soa全新架构推出还是oo的持续发展,他们都追求同一个终极目标:松耦合。
当我们在java波涛汹涌的潮流中奋击时,我们常常会思考?我为什么要这样做?甚至,我们会想松耦合真的那么酷?可维护性真的是软件唯一?也许我们迷失了方向。
我们要好好探究一下,软件的最大追求是什么?
我们的大学计算机教育只是教会我们如何编程?这如同技工学校中教会学员如何使用车床一样,当我们学会了编程,接下来是什么呢?是不是就没有了呢?是不是就是如同车工那样只需日复一日的反复编程呢?
其实,当你在一个系统中持续编程(增加新的东西),这个系统就变得复杂了,你面临最大的挑战是如何整理你自己的产物。
也就是说:大学教育只教会我们如何“增加新的东西”,但是没有教育我们如何“整理这些东西”,而后者是目前软件领域日新月异不断发生的革命的新动力。
下面我们以具体代码来说明“增加新的东西”和“整理这些东西”完全属于不同层次的学问,有些人谈到软件只会想到算法和数据结构,认为这些才是科学,其实这是将软件数学化,软件不只是科学计算的工具,它自身也是一门科学,更象管理学/经济学一样,是科学和艺术的结合。
在最近java(tm) boutique网站上刊登出一篇文章measuring the complexity of oo systems,衡量 oo系统的复杂性,该文对软件复杂性几个著名公理进行了详细阐述,这些公理如果你不进行学习和培训,即使你使用oo语言java等这样工具,还是显示你是 “业余”的。
软件复杂性包括以下部分(引自measuring the complexity of oo systems):
* cyclomatic complexity (圈复杂性)
* response for class (类的响应)
* weighted methods per class (每个类重量方法)
cyclomatic complexity
cyclomatic complexity可以用下面代码来说明:
cyclomatic complexity (cc) = number of decision points 1
其中number of decision points是指一个if else之类的条件判断语句,比如,是下面这个条语句:
public void isvalidsearchcriteria(searchcriteria s){
if(s!=null) {
return true;
}else{
return false;
}
}
本文来源:https://shitiku.jxxyjl.com/ruanjianshuipingxuexizhinan/49069.html
-
交换机连接交换机_交换机系列培训:交换机性价比基准测试详细阅读
美国《network world》与tolly group近期联合进行的switchmetric(第3轮)测试结果显示,基于铜线交换技术的进步及来自新厂商的竞争是千兆以太网交换价格下降的主要原因。这次测试于3月和4月在tolly group试验室进行,对一些具有大规模端口配置交换机的测试...
-
[希赛网络工程师讲义]网络工程师辅导班讲义详细阅读
内容简介:第3章 交换技术 主要内容:1、线路交换 2、分组交换 3、帧中继交换 4、信元交换 一、线路交换1、线路交换进行通信:是指在两个站之间有一个实际的物理连接,这种连接是结点之间线路的连接序列。2、线路通信三种状态:线路建立、数据传送...
-
面向对象程序设计常用类型思维导图_面向对象程序设计C++的const类型详细阅读
常类型是指使用类型修饰符const说明的类型,常类型的变量或对象的值是不能被更新的。因此,定义或说明常类型时必须进行初始化。 一般常量和对象常量 1 一般常量 一般常量是指简单类型的常量。这种常量在定义时,修饰符const可以用在类型说明符前,也可以用在类型说明符后。如:...
-
【软浮云软件】软件指导:软设过关经验谈详细阅读
一,有标准辅导教材,学习方便,不要到处去找相关的书看了,比如软件工程、数据库、数据结构啊什么的。有了标准教材复习有个范围,这样就不会盲目乱复习了,或者漏复习部分内容。可以以标准教材为中心,其它资料为参考,复习有主次,这样进步应该比较快。 二,有经验丰富的老师指导,遇到问题能及时解决...
-
计算机软件水平考试与计算机四级_计算机软件水平考试应避免的五大失误详细阅读
上机操作不当-成绩不算在考试前,请仔细听清监考老师所说的一些考试注意事项,不要急于操作。我们知道,有关计算机的考试,其成绩是直接记录在计算机上的,考试过程中,如果因为你的操作不当,而将你的考试成绩或准考证号等丢失,你的辛苦将付之东流,这恐怕是你最不愿看到的失误吧。考题跳做-不给分参加考试如...
-
【使用chrome浏览器】使用C#在应用程序之间发送消息详细阅读
首先建立两个c 应用程序项目。 第一个项目包含一个windows form(form1),在form1上有一个button和一个textbox。 第二个项目包含一个windows form(form1),在form1上有两个button,分别用来测试第一个应用程序中butt...
-
[在uml的需求分析建模中 对用例模型]UML用例建模的慨念和应用详细阅读
一. uml简介 uml(统一建模语言,unified modeling language)是一种定义良好、易于表达、功能强大且普遍适用的可视化建模语言。它融入了软件工程领域的新思想、新方法和新技术。它的作用域不限于支持面向对象的分析与设计,还支持从需求分析开始的软件开发的全过程。在...
-
【ping命令的工作原理】ping命令工作原理详细解析详细阅读
内容简介: ping的原理就是首先建立通道,然后发送包,对方接受后返回信息,这个包至少包括以下内容,发送的时候,包的内容包括对方的ip地址和自己的地址,还有序列数,回送的时候包括双方地址,还有时间等,主要是接受方在都是在操作系统内核里做好的,时刻在监听,提供一段c程序的代码,希望对大家有用。...
-
445端口常见漏洞|常见端口的作用、漏洞和操作建议(2)详细阅读
21端口:21端口主要用于ftp(file transfer protocol,文件传输协议)服务。 端口说明:21端口主要用于ftp(file transfer protocol,文件传输协议)服务,ftp服务主要是为了在两台计算机之间实现文件的上传与下载,一台计算机作为ftp客户...
-
如何使用打印机_如何使用ADO.NET轻松操纵数据库详细阅读
ado net提供了connection来连接数据库,同时也提供了command对象来查询数据库。同connection对象一样,command也有两种:oledbcommand和sqlcommand 其区别同connection对象。 要操纵数据库,必须先使用connect...