本文主要是介绍开放封闭原则之“面向接口编程”,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
前言:
同样是开放封闭原则,在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 数据库*/@Overridepublic boolean countScoreByPaperId(String couserId, String examId, String paperId,String dataBaseName) {// 第一步将所有的记录查出来!!boolean flag = false;Map<Serializable, Serializable> map = new HashMap<Serializable, Serializable>();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<PaperRecord> list = new ArrayList<PaperRecord>();try {// 查询到学生,和成绩信息。list = calculateScoreEao.queryByHql(hqlstrString, map, dataBaseName);List<StudentScore> liststudent = new ArrayList<StudentScore>();for (int i = 0; i < list.size(); 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<PaperRecord> 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<PaperRecord> queryStuAndMarkScoreByKeyword(String couserId, String paperId,String dataBaseName){Map<Serializable, Serializable> map = new HashMap<Serializable, Serializable>();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*/@Overridepublic boolean countScoreByPaperId(String couserId, String examId, String paperId,String dataBaseName) {// 第一步将所有的记录查出来!!boolean flag = false;List<PaperRecord> list = new ArrayList<PaperRecord>();try {// 查询到学生,和成绩信息。list = calculateScoreEao.queryStuAndMarkScoreByKeyword(String couserId, String paperId,String dataBaseName);List<StudentScore> liststudent = new ArrayList<StudentScore>();for (int i = 0; i < list.size(); i++) {Object ojb = (Object) list.get(i);Object[] objs = (Object[]) ojb;
小结:
特别是在ITOO这种大型的平台,利用面向接口的编程思想就更能体现出扩展性和维
护性了,ITOOJava平台现在还没有上线,即使是上线之后,也是需要不断的扩展和维护
了,将集成改成接口之后,就真正的做到了开放封闭的原则,方便以后的扩展和维护,
实际操作中也方便分模块的分工协作,就一个大项目肯定是需要很多人一同去协作来做
的,这正明显的提高了运行效率、开发和维护的效率。
这篇关于开放封闭原则之“面向接口编程”的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!