当前位置 : 主页 > 网络编程 > 其它编程 >

开放封闭原则之“面向接口编程”

来源:互联网 收集:自由互联 发布时间:2023-07-02
开放封闭原则之“面向接口编程” 前言:   同样是开放封闭原则,在ITOOjava的项目中,对“面向接口编程”又有了更深刻的理解,下面请听自由互联小编徐徐道来:   开放封闭原则
开放封闭原则之“面向接口编程” 前言:   同样是开放封闭原则,在ITOOjava的项目中,对“面向接口编程”又有了更深刻的理解,下面请听自由互联小编徐徐道来:   开放封闭原则定义:

开放封闭原则之“面向接口编程”

前言:

同样是开放封闭原则,在ITOOjava的项目中,对“面向接口编程”又有了更深刻的理解,下面请听自由互联小编徐徐道来:

开放封闭原则定义:用面向接口编程这就为我们以后程序的扩展性提供基础。“对修改封闭,对扩展开发”。

利用接口的一个基本用途,规定子类的行为。更为广阔的用途是接口为其他人使用者提供什么用途。模块和模块之

间的解耦就看你的接口设计的是不是合理,是不是好用。这才是从框架设计师角度去思考问题了。

什么是接口?

接口就是标准,是用来隔离具体实现的(或者说是和具体实现解耦)。举个生活中的例子就是:各种手机、移动硬

盘等连接上上的USB接口就是标准,大家各自制造自己的具体产品。产品使用者和提供者都遵守这个标准,那么使用

者就不必担心自己电脑上的USB接口是否只能插移动硬盘而不能插手机。

为什么要用接口 ?

主要是是用于处理多变的情况。

(1)接口在实际开发过程中最大好处是,你可以按照设计,先把接口写好,然后分配大伙干活的时候,告诉a们去用写好的接口去实现他们的具体功能,而告诉b们,去写那些已经写好但是没有具体的代码的接口,这样可以提高工作效率。并且底层和应用也通过接口做了一个很明显的分层。

(2)接口可以降低耦合性,换句话说,可以让某个模块或功能能够重复利用,这样只要写这功能一次代码就ok了。其他地方要用到的,全部用接口调用来实现

(3)合理使用接口、继承,拥有良好架构的程序,二次开发上可能会节省很多时间,因为它低耦合 扩展性高。

ITOOJava5.0 代码

走查之面向接口编程:原来的Service界面:

/** * 修改人:通过课程Id、考试Id、试卷Id和数据库表名来计算分数+Daniel+2016-6-14 * @param couserId 课程Id * @param examId 考试Id * @param paperId 试卷Id * @param dataBaseName 数据库 */ @Override public boolean countScoreByPaperId(String couserId, String examId, String paperId, String dataBaseName) { // 第一步将所有的记录查出来!! boolean flag = false; Map map = new HashMap(); map.put("couserId", couserId); map.put("paperId", paperId); String hqlstrString = "select t.studentID,t.studentName, SUM(t.score) as markScore From PaperRecord t where t.courseID=:couserId and t.paperId=:paperId GROUP BY t.studentID"; List list = new ArrayList(); try { // 查询到学生,和成绩信息。 list = calculateScoreEao .queryByHql(hqlstrString, map, dataBaseName); List liststudent = new ArrayList(); for (int i = 0; i 把SQL语句写在CalculateScoreEao.java 中,创建一个接口:

/** * 修改人:通过课程Id、考试Id、试卷Id和数据库表名来计算分数+Daniel+2016-6-14 * @param couserId 课程Id * @param examId 考试Id * @param paperId 试卷Id * @param dataBaseName 数据库表名 */ public List queryStuAndMarkScoreByKeyword(String couserId, String paperId, String dataBaseName);

在CalculateScoreEaoImpl.java 中实现这个接口:

/** * 修改人:通过课程Id、考试Id、试卷Id和数据库表名来计算分数+Daniel+2016-6-14 * @param couserId 课程Id * @param examId 考试Id * @param paperId 试卷Id * @param dataBaseName 数据库表名 */ public List queryStuAndMarkScoreByKeyword(String couserId, String paperId, String dataBaseName){ Map map = new HashMap(); map.put("couserId", couserId); map.put("paperId", paperId); String hqlstrString = "select t.studentID,t.studentName, SUM(t.score) as markScore From PaperRecord t where t.courseID=:couserId and t.paperId=:paperId GROUP BY t.studentID"; return this.CalculateScoreEao.queryStuAndMarkScoreByKeyword(String couserId, String paperId, String dataBaseName);}

之后:CalculateScoreServiceImpl.java中代码如下:

《开放封闭原则之“面向接口编程”》

优化后:

/** * 修改人:通过课程Id、考试Id、试卷Id和数据库表名来计算分数+Daniel+2016-6-14 * @param couserId * @param examId * @param paperId * @param dataBaseName */ @Override public boolean countScoreByPaperId(String couserId, String examId, String paperId, String dataBaseName) { // 第一步将所有的记录查出来!! boolean flag = false; List list = new ArrayList(); try { // 查询到学生,和成绩信息。 list = calculateScoreEao .queryStuAndMarkScoreByKeyword(String couserId, String paperId, String dataBaseName); List liststudent = new ArrayList(); for (int i = 0; i 小结:

特别是在ITOO这种大型的平台,利用面向接口的编程思想就更能体现出扩展性和维

护性了,ITOOJava平台现在还没有上线,即使是上线之后,也是需要不断的扩展和维护

了,将集成改成接口之后,就真正的做到了开放封闭的原则,方便以后的扩展和维护,

实际操作中也方便分模块的分工协作,就一个大项目肯定是需要很多人一同去协作来做

的,这正明显的提高了运行效率、开发和维护的效率。

网友评论