[软件合集软件]软件指导:软件最大的追求是什么
【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
-
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...
-
软考考前卖答案_软考考前心理调整八种方法详细阅读
随软考的临近,不知道是不是有考生会很紧张,出现以下症状:对考试产生害怕、忧虑、不安等情绪,对考试结果缺乏信心,精神处于高度紧张状态,有时还伴有头痛、失眠、食欲不振、脾气暴躁、焦躁不安、注意力不集中、头脑发木等反应,甚至对考试产生严重的恐惧感。这就是我们常说的考试焦虑。心理学研究表明,...
-
[程序员逻辑思维培养]职业程序员培养之道详细阅读
软件开发是以人为核心的过程,对人的依赖性远高于传统的硬件生产企业,为了保持开发能力的稳定性,一方面需要定义软件过程,以过程为枢纽将人、技术、工具衔接起来,另一方面也要加强人才的培养,使人的工作能力能够稳定、提高人员的自治性。随着社会需求的膨胀,对程序员的需求量、对熟练的程序员的需求量在剧...
-
【指针万用表的使用方法】C++指针使用方法解惑详细阅读
c++指针使用方法解惑 void clearlist(lnode * & hl) 仔细看一下这种声明方式,确实有点让人迷惑。 下面以 void func1( myclass *&pbuildingelement ); 为例来说明这个问题。在某种意义上,*和&是意思相对的两个东西,把它们放在...
-
【ctoc模式什么意思】CtoC++新手指南详细阅读
c++技术固然是很时髦的,许多c用户都想在尽可能短的时间内为自己贴上c++的标签。介绍c++的书很多,但只有那些已经侥幸入门的用户才偶尔去翻翻,仍有不少在c++门口徘徊的流浪汉。 本文只针对c用户,最好是一位很不错的老用户(譬如他在遇到最简单的问题时都尝试着使用指针),通过一些c和更好的c++(本文...
-
线性表的顺序实现_使用C++实现线性表的基本功能详细阅读
include include include typedef int elemtype; 线性表的基本操作void initiallist(elemtype *l); int isempty(elemtype *l);void l...
-
计算机软件水平考试与计算机四级|计算机软件水平考试:《数据结构》是核心详细阅读
从2004年起,计算机与软件考试纳入全国专业技术人员职业资格证书制度的统一规划,报考任何级别的考生都不受学历、资历限制,这使得该考试报考人数骤增。而20%通过率无疑使该考试的竞争非常激烈,怎样能顺利通过考试已成为广大参考人员的热门话题。 为了让考生更好的备考,我们特走访了多位已经通过考试的朋...
-
软考 软考_软考专家谈软考趋势和复习要点详细阅读
2005 年上半年全国计算机技术与软件专业技术资格(水平)考试(简称软考)报考人数最多的专业级别是软件设计师和程序员。这两个级别是软件考试中最经典、考题最稳定和考生最多的级别,同时也是社会认同度最高的两个级别。近年来,随着信息技术的发展,考试内容的重点已作较大调整,考试更能体现出技术的进...
-
[路由器与交换机的主要区别]深入了解路由器与交换机的区别3详细阅读
2 负载集中:交换机之间只能有一条通路,使得信息集中在一条通信链路上,不能进行动态分配,以平衡负载。而路由器的路由协议算法可以避免这一点,ospf路由协议算法不但能产生多条路由,而且能为不同的网络应用选择各自不同的最佳路由。 3 广播控制:交换机只能缩小冲突域,而不能缩小广播域。整个交换...