java开发 有人说设计模式是为了弥补Java语言的缺陷,你觉得是这样吗?
有人说设计模式是为了弥补Java语言的缺陷,你觉得是这样吗?
如果你从语言的角度来看设计模式,那是对的。一些设计模式弥补了Java语言的不足,其中最明显的是singleton模式。
Java本身不提供单例对象创建,需要通过单例模式实现。什么样的饿、懒、多线程都要注意DCL、易变关键字等,导致面试题很多。
在许多现代语言中,如kotlin,提供关键字。
从架构的角度来看,设计模式将组件关系解耦。
假设我们要实现一个带有上载服务的文件服务器来上载文件。我们可以调用convertservice来转换文件。Uploadservice属于核心模块upload module,convertservice属于非核心模块conversion module。
如果uploadservice直接调用convertservice来执行转换,则核心模块依赖于非核心模块。如下图所示:
非核心模块相对不稳定,核心模块相对稳定。核心模块对非核心模块的依赖将导致核心模块的不稳定性。所以可以使用策略模式来解耦:
看箭头方向,现在转换模块依赖于上传模块,转换模块的变化不会影响上传模块。依赖的方向改变了。这就是传说中的“依赖倒置”
写JAVA后端代码时逻辑混乱怎么办?
后端代码的复杂性通过分割和裁决来解决。首先,通过拆分项目,项目之间可以存在依赖关系,但必须是单向依赖而不是环依赖。如果存在环,我们必须考虑将环依赖分解为单独的项目来解决环依赖。
对于项目中的代码,可以通过水平拆分和垂直拆分来降低复杂性。水平层分为控制器、服务、Dao和sqlmap,垂直层分为系统、biz1、biz2、Bizn,但在数据通畅连接中,水平拆分和垂直拆分相结合,如下图所示:
通过这种分层方式,代码层是分开的,结构清晰。对于一些跨模块调用的接口,如同一个数据表需要在不同的模块中操作时,可以将该接口作为公共接口升级到上层cxmodule,对于一些可重用的、相对独立的功能,可以在cxmodule中定义一个干净的接口,业务逻辑可以通过在模块的功能模块中实现接口来实现,而不需要使用spring的事务管理机制,从而降低代码的复杂度。
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。