悠然乱弹:从几个方法的重构讲开去--性能大优化

现在还存在多次扫描处理的问题,也就是说虽然代码结构性重构是成功的,但是性能问题还是没有根本解决。

在给出解决方案之前,需要对这个处理方式缕一缕:

处理方式1:每次遍历全路径找到待处理文件,文件然后批量进行处理。优点是处理起来比较简单,但是会重复扫描。

处理方式2:一次遍历所有文件,然后对每个文件进行注解检测。扫描全路径只有一次,然后要把每个文件与过滤器进行比较如果比较成功那就做,比较不成功就不做。

稍加分析就会发现,两种方式的比较次数是一样的,但是第二种方案遍历文件的次数就少到极限了,还能比1次更少么??

这次的做法就有点复杂了(相对的,实际上也很简单),做一个过滤器,里面放个Map存储过滤器:处理器。

对于每个一个文件,都对所有的过滤器进行校验,如果校验成功,就执行对应的处理器。

?


1

2

3

4

5

6

7

8

9

10

11

public class ComplexFileFilter implements FileObjectFilter {

    Map<FileObjectFilter,FileObjectProcessor> filterProcessorMap;

    public boolean accept(FileObject fileObject) {

        for(FileObjectFilter filter:filterProcessorMap.keySet()){

            if(filter.accept(fileObject)){

                filterProcessorMap.get(filter).process(fileObject);

            }

        }

        return false;

    }

}

呵呵,性能的问题也提升完毕了。

至此,从几个看似重复的方法,我们通过层层分析,细致推理,终于找到了内部的复杂关系,通过重构,给程序员以便捷的开发与扩展,给使用者以高效的性能和一目了然的逻辑,皆大欢喜了。

总结:许多的时候,一些纠结,重复,无从动手,都是有其内在的复杂因素的,之所以剪不断理还乱,是因为没有抓住实质,但只要把它理顺了,其实各干干的,就简单了。

时间: 2024-08-02 15:04:36

悠然乱弹:从几个方法的重构讲开去--性能大优化的相关文章

悠然乱弹:从几个方法的重构讲开去--注解相关的处理

有时候它们的处理没有关联性,有些时候,它们的处理又是有关联性的. 我们用伪代码来示意一下. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 if(includeAnnotation(testClass,Abc.class)){   doSomething... }   if(includeAnnotation(testClass,Abc.class)){   for(Field field:testClass.getFields){     if(include

悠然乱弹:从几个方法的重构讲开去--文件相关的处理

简单看看吧,确实没有什么好的解决方案,那我们就抽丝剥茧,看看这三个方法里都涉及到哪些个领域? 涉及到注解方面的处理 涉及到多种注解方面的处理 涉及到文件查找方面的问题 涉及到多种资源文件查找方面的问题-file,jar 涉及到对查找到资源文件之后的后续处理的问题 好吧,可能还有别的问题,我们先利用上面分析出来的问题,看看有没有着手之处?? 仔细分析下来,暂时有三种要遍历的文件了,file,jar,自定义ClassLoader,那我们简单抽象一下: ? 1 2 3 4 5 6 7 8 9 10 1

悠然乱弹:从几个方法的重构讲开去--引言

引言: 在学习代码的过程中,看到如下几个工具方法: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77

悠然乱弹:从一段代码讲开去

序言 今天偶然看到一框架,在框架的里面有一段这样的描述: ? 1 2 xxx并不愿意其他人来直接修改YYY框架的代码,因为XXX致力于将它打造为完美的作品,其他人写的代码,实在没有加入进来的意义. 但是您可以当小白鼠,提意见,提bug,好的idea我还是愿意接受的. 这里解释一下,其中xxx是作者名字,YYY是框架名称,这么OSC上牛人众多,牛到这个程度的还是第一次见到,于是就想去速度学习一下.其实框架好不好,看例子代码就可以看出一二,去找了找,果然找到了示例代码,我摘了两个方法: ? 1 2

悠然乱弹:一段SQL引发的性能危机及其背后隐藏的设计缺陷

故事发生的背景是,在文件上传的时候,有时间会有人上传了文件,但是最后没有使用上传的文件,这样就会产生一些垃圾文件. 原来软件作者就想写一个后台定时任务程序,来清除这些垃圾文件? 由于作者坚定的不让我发她的SQL语句(这个我也理解,这么丑陋的SQL),所以这里就不发源代码了,发伪代码. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 void deleteMissLinkFile{   List fileList=getFileList();   List delete

悠然乱弹:螺旋矩阵和蛇型矩阵的悠然版实现

螺旋矩阵和蛇型矩阵,是两个比较有趣的矩阵,有许多的公司面试题中有出现,这两个题的答案也有许多种,简单问一下度娘,就各自有N种实现,来源也非常丰富,比如CSDN.ITEYE.等等,当然也包括著名的OSC,但是整体看下来,呵呵,比较顺眼的比较少,比较经典的就越发少了. 考虑到不同的语言有不同的语言特性,因此今天就只用Java来进行实现,看看螺旋矩阵和蛇型矩阵的悠然版实现,让我们的OSC也更加高大上一些,. 概念说明 什么是螺旋矩阵 螺旋矩阵是指一个呈螺旋状的矩阵,它的数字由第一行开始到右边不断变大,

工厂方法真的支持OCP 开闭原则吗?

问题描述 工厂方法真的支持OCP 开闭原则吗? 开闭原则:我们在设计一个模块的时候应当使这个模块可以在不被修改的前提下被扩展换句话说就是应当可以在不必修改源代码的情况下改变这个模块的行为.工厂方法增加新的方法类的时候,不是要修改接口.然后再修改所有的相关类么.这岂不是违背了开闭原则 解决方案 工厂什么的都只是假象,利用反射可以

onmouseover方法总是报“document未定义” 求大神看看

问题描述 onmouseover方法总是报"document未定义" 求大神看看 var om = domcument.getElementById("div1"); om.onmouseover = function(){ this.style.cursor='hand'; return true; } om.onmouseout = function(){ this.style.cursor='default'; return true; } <div i

我在客户端如何可以取得服务器端的最新数据(前10条),除了定时刷新的方法,还有别的方法吗?而且数据量较大,要保证速度。希望各位大侠、高手给写建议。

问题描述 我在客户端如何可以取得服务器端的最新数据(前10条),除了定时刷新的方法,还有别的方法吗?而且数据量较大,要保证速度.希望各位大侠.高手给写建议. 解决方案 解决方案二:ajax从服务器上每次只取20条即可速度上影响不大