作者:JJ关键词 | 来源:互联网 | 2023-07-01 21:56
开放封闭原则之“面向接口编程” 前言: 同样是开放封闭原则,在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 Object ojb = (Object) list.get(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 Object ojb = (Object) list.get(i);
Object[] objs = (Object[]) ojb;
小结: 特别是在ITOO这种大型的平台,利用面向接口的编程思想就更能体现出扩展性和维
护性了,ITOOJava平台现在还没有上线,即使是上线之后,也是需要不断的扩展和维护
了,将集成改成接口之后,就真正的做到了开放封闭的原则,方便以后的扩展和维护,
实际操作中也方便分模块的分工协作,就一个大项目肯定是需要很多人一同去协作来做
的,这正明显的提高了运行效率、开发和维护的效率。