【设计模式】一个代码抽离功能居然用上3种设计模式,飞机太大拉不动
【设计模式】一个代码抽离功能居然用上3种设计模式,飞机太大拉不动
逗比经理又来找Egan帮忙了
Egan接下这个活后看着自己日渐稀少的头发
接近一百个Dao接口类,这活是人干的么,这是熬夜搬砖也搬不完。
这怎么搬,得有起重机啊,难道要我自己造?
Egan突然灵光一闪:那我就自己造一个起重机
先写一个脚本把Dao接口拷贝至基础服务模块里面,机智的Egan想到直接用DOS命令去迁移。
首先需要创建目标目录(mkdir命令),然后在执行copy命令,大概就是这样的
想了想这样一个一个执行过去也慢,写程序吧。
Egan构思了一下主要几个部分组成:
拷贝Dao接口、Dao.xml 至对应的基础服务模块
拷贝实体类(dto,entyty等等)至对应的数据接口服务模块
解析Dao接口去除内部杂质得到DataServiceIntf接口并保存至数据接口服务模块
解析Dao接口去除内部杂质解;解析方法得到参数并将抽象方法变成具体的方法,内部调用Dao对应的方法。保存至基础服务模块类名XXXDataService
差不多就这样了,归类之后变成三类:
不需要解析直接拷贝文件
需要解析并处理
不需要处理的文件(用于匹配以上4个组成部分)
就这样抽象出一个接口类,三个抽象方法
接着Dao接口类、Dao.xml、实体为直接拷贝的方式,那么这里他们的区别就是目标文件的路径不一样,那么可以编写一个中庸的抽象类把目标文件路径抽象出来。
接口与抽象类编写完差不多然后把所有的类先创建号,类图差不多就是这样子的
编写Dao文件处理器实现类
编写实体文件处理器实现类
完美,拷贝方式就这样写完了。
赞,Dao转DataServiceIntf也编写完成
Egan继续编写剩余的类
编写完成。
最后只剩启动类,需要对文件遍历处理
滴答滴答
编写终于编写完成啦
启动试试。全部成功处理完成。
不到一天就完成任务了,哈哈哈,自夸一下,庆祝下,今晚加餐
嘻嘻,今天就不跟逗比经理说完成了,划水一下,明天再跟他说完成了,让他奖励一波。
滴答滴答
第二天
Egan超开心开心,暗喜道:有加餐的活就应该多来一些
你们觉得Egan编写这套组件运用了哪几种设计模式?可在下方留言哦。
往期热门文章:

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Rook 1.5.1 部署Ceph实操经验分享
一、Rook概述 1.1 Rook简介 Rook 是一个开源的cloud-native storage编排, 提供平台和框架;为各种存储解决方案提供平台、框架和支持,以便与云原生环境本地集成。目前主要专用于Cloud-Native环境的文件、块、对象存储服务。它实现了一个自我管理的、自我扩容的、自我修复的分布式存储服务。 Rook支持自动部署、启动、配置、分配(provisioning)、扩容/缩容、升级、迁移、灾难恢复、监控,以及资源管理。为了实现所有这些功能,Rook依赖底层的容器编排平台,例如 kubernetes、CoreOS 等。。 Rook 目前支持Ceph、NFS、Minio Object Store、Edegefs、Cassandra、CockroachDB 存储的搭建。 项目地址:https://github.com/rook/rook 网站:https://rook.io/ <!--more--> 1.2 Rook组件 Rook的主要组件有三个,功能如下: Rook Operator Rook与Kubernetes交互的组件 整个Rook集群只有一个 A...
- 下一篇
Flink从入门到真香(16、Flink内置的一些Process Function)
之前的转换算子是无法访问事件的时间戳信息和水位线信息的,而这在一些应用场景下,极为重要。例如MapFunction这样子的map转换算子就无法访问时间戳或者当前事件的事件事件。 基于此,DataStream API提供了一系列LOW-LEVEL的转换算子调用。可以访问时间戳,watermark以及注册定时事件,还可以输出特定的一些事件,例如超时时间等。process function用来构建事件驱动的应用以及实现自定义的业务逻辑(使用之前的window函数和转换算子无法实现)。例如Flink SQL就是使用Process Function实现的。 Flink提供了8个 Process Function ProcessFunction KeyedProcessFunction CoProcessFunction ProcessJoinFunction BroadcastProcessFunction KeyedBroadcastProcessFunction ProcessWindowFunction 下面几个栗子来一一说明: 栗子1- 实现一个连续15秒如果温度持续上升就报警 pack...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Hadoop3单机部署,实现最简伪集群
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- SpringBoot2整合Redis,开启缓存,提高访问速度
- Windows10,CentOS7,CentOS8安装Nodejs环境
- MySQL8.0.19开启GTID主从同步CentOS8
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- 设置Eclipse缩进为4个空格,增强代码规范