paip.提升效率---filter map reduce 的java 函数式编程实现

时间:2023-02-03 15:06:38

#paip.提升效率---filter map reduce 的java 函数式编程实现

========================================================

#----------------------index索引------------------

++函数式编程的好处儿以及缺点

++actual code 实际代码如下

---filter 实现...

--- map 实现..

---reduce

---调用



##函数式编程的好处儿以及缺点

----------------------------

从声明式编程 代替  命令式编程 的观点来看,函数式编程是个好东东..why >>>how

大多时间哈,,可以容易的理解..

大多时间哈,更是代码短....



但是,有时候,代码更多,更长的...估计是java7 没实现lambda 表达式造成的吧..

reduce 使用的递归,可能更多的对象生成,,以及堆栈溢出...毕竟,现在的电脑都是基于寄存器的...不是基于堆栈机器..不是基于lambda list机...





作者 老哇的爪子 Attilax 艾龙,  EMAIL:1466519819@qq.com

来源: http://blog.csdn.net/attilax



##actual code 实际代码如下

----------------



###filter 实现...

public static <atiType> atiType filterO4(atiType arr, Func func) {

        // List li = new ArrayList();

        // for (int i = 0; i < objLi.size(); i++) {

        // String string = objLi.get(i);

        // boolean o = (Boolean) func.invoke(string);

        // if (!o)

        // li.add(string);

        // }



        List li = new ArrayList();

        if (arr instanceof String[]) {

            String[] sa = (String[]) arr;

            for (int i = 0; i < sa.length; i++) {

                String charx = sa[i];

                if (!(Boolean) func.invoke(charx))

                    li.add(charx);



            }

            return (atiType) toStrArr(li);

        }

        if (arr instanceof List) {

             List li3=(List) arr;

            for (int i = 0; i <li3.size(); i++) {

                String charx = (String) li3.get(i);

                if (!(Boolean) func.invoke(charx))

                    li.add(charx);



            }

            return (atiType)  (li);

        }



        return null;

    }



    ### map 实现..

    

    public static List<String> mapx(Object li, Func function) {

        List lir = new ArrayList();

        if (li instanceof List) {

            List objLi = (List) li;

            for (int i = 0; i < objLi.size(); i++) {

                Object o = function.invoke(objLi.get(i));



                lir.add(i, o);

            }

        } else {

            Object[] objLi = (Object[]) li;

            for (int i = 0; i < objLi.length; i++) {

                lir.add(function.invoke(objLi[i]));

            }

        }

        return lir;

    }

    

###reduce

public static <atiType,retType> retType reduceO4d(atiType obj,   Func function) {

    

        retType lastVal = null;

        

        if (obj instanceof List) {

            if(lastVal==null)

                lastVal=(retType) new ArrayList();

            

            List objLi = (List) obj;

            for (int i = 0; i < objLi.size(); i++) {

                lastVal =   (retType) function.invoke(lastVal, objLi.get(i));



            }

            return (retType) lastVal;

        }

        return null;

    }

###调用

public static void main(String[] args) {

        String f = "c:\\li.txt";

        List<String> li = filex.read2list(f);

        List<String> li2 = listUtil.reduceO4d(li, new Func() {



            @Override

            public Object invoke(Object... o) {

                List Last = (List) o[0];

                String s = (String) o[1];

                if (s.contains("@")) {

                    String[] a = s.split("\\t");

                    String nowSlect = a[0].trim().replaceAll("@", "");

                    List li_now=listUtil.toList(nowSlect);

                    li_now=listUtil.deDulicate(li_now);

                    return  Last.addAll(li_now);

                }

                return Last;



            }

        });

        filex.saveList2file(li2, "c:\\catch.txt");

    }

paip.提升效率---filter map reduce 的java 函数式编程实现的更多相关文章

  1. paip&period;提升性能--多核cpu中的java&sol;&period;net&sol;php&sol;c&plus;&plus;编程

    paip.提升性能--多核cpu中的java/.net/php/c++编程 作者Attilax  艾龙,  EMAIL:1466519819@qq.com  来源:attilax的专栏 地址:http ...

  2. paip&period;提升效率--批量变量赋值 &OpenCurlyDoubleQuote;多元”赋值

    paip.提升效率--批量变量赋值 "多元"赋值 ##石麻是批量变量赋值. 为一组变量赋值. 例子 1 <?php $my_array = array("Dog&q ...

  3. paip&period;提升效率---request自动绑定domain object

    paip.提升效率---request自动绑定domain object #.keyword,subtitle关键字,子标题 ------------------------- 复制request属性 ...

  4. paip&period;提升效率--gui 的选择--swing最佳实践swt awt

    paip.提升效率--gui 的选择--swing最佳实践swt awt ////////////////弹出消息框. ////////////////myeclipse swing 开发最佳实践.. ...

  5. Python经常使用内置函数介绍【filter&comma;map&comma;reduce&comma;apply&comma;zip】

    Python是一门非常简洁,非常优雅的语言,其非常多内置函数结合起来使用,能够使用非常少的代码来实现非常多复杂的功能,假设相同的功能要让C/C++/Java来实现的话,可能会头大,事实上Python是 ...

  6. filter&comma;map&comma;reduce&comma;lambda(python3)

    1.filter filter(function,sequence) 对sequence中的item依次执行function(item),将执行的结果为True(符合函数判断)的item组成一个lis ...

  7. paip&period;提升效率--数据绑定到table原理和流程Angular js jquery实现

    paip.提升效率--数据绑定到table原理和流程Angular js  jquery实现 html #--keyword 1 #---原理和流程 1 #----jq实现的代码 1 #-----An ...

  8. paip&period;提升效率--调试--日志系统日志参数含义---python

    paip.提升效率--调试--日志系统日志参数含义---python #同时向控制台和文件输出日志 #日志参数含义 import logging log_format = '%(filename)s ...

  9. paip&period;提升效率--僵尸代码的迷思

    paip.提升效率--僵尸代码的迷思 僵尸代码是指你的代码库里被注释掉的那部分代码, 很少去使用它,就像僵尸一样, 看雷kill-the-zombies-in-your-code ========== ...

随机推荐

  1. 系统级性能分析工具perf的介绍与使用

    测试环境:Ubuntu16.04(在VMWare虚拟机使用perf top存在无法显示问题) Kernel:3.13.0-32 系统级性能优化通常包括两个阶段:性能剖析(performance pro ...

  2. 如何在sharepoint2010中配置Google Anlytics 分析服务

      简介 Google Analytics(分析)不仅可以帮助您衡量销售与转化情况,而且能为您提供新鲜的深入信息,帮助您了解访问者如何使用您的网站,他们如何到达您的网站,以及您可以如何吸引他们不断回访 ...

  3. CentOS7安装mysql5

    CentOS7的yum源中默认没有mysql. 1. 下载mysql的repo源 $ wget http://repo.mysql.com/mysql-community-release-el7-5. ...

  4. 使用uiautomator做UI测试

    转载~~~~~~~~~~~~~~~~~~~~~~~~ 若有侵权,请及时联系本博主,博主将第一时间撤销 在Android 4.1发布的时候包含了一种新的测试工具–uiautomator,uiautoma ...

  5. Codeforces 474D Flowers dp(水

    题目链接:点击打开链接 思路: 给定T k表示T组測试数据 每组case [l,r] 有2种物品a b.b物品必须k个连续出现 问摆成一排后物品长度在[l,r]之间的方法数 思路: dp[i] = d ...

  6. Bootstrap入门(二十三)JS插件1:模态框

    Bootstrap入门(二十三)JS插件1:模态框 1.静态实例 2.动态实例 3.模态框的尺寸和效果 4.包含表单的模态框 模态框经过了优化,更加灵活,以弹出对话框的形式出现,具有最小和最实用的功能 ...

  7. poj3254 炮兵阵地弱化版,记数类dp

    /* dp[i][j]表示到第i行的状态j有多少放置方式 */ #include<iostream> #include<cstring> #include<cstdio& ...

  8. BFS算法(——模板习题与总结)

    首先需要说明的是BFS算法(广度优先算法)本质上也是枚举思想的一种体现,本身效率不是很高,当数据规模很小的时候还是可以一试的.其次很多人可能有这样的疑问,使用搜索算法的时候,到底选用DFS还是BFS, ...

  9. 进化论VS中性突变理论

    进化论VS中性突变理论 查尔斯·罗伯特·达尔文(英语:CharlesRobert Darwin,1809年2月12日-1882年4月19日),英国生物学家,其“进化论”被列为19世纪自然科学的三大发现 ...

  10. ant design pro (四)新增页面

    一.概述 参看地址:https://pro.ant.design/docs/new-page-cn 这里的『页面』指配置了路由,能够通过链接直接访问的模块,要新建一个页面,通常只需要在脚手架的基础上进 ...