java8函数式参数

小叙:最近维护项目的时候看到有人写这种代码,而且呈现递增形势,自己查了一下,发现是java8的新特性。

复制代码
List<Coordinate> rs1 = service.simplfy(set, new Function<String, Coordinate>() {
            @Override
            public Coordinate apply(String s) {
                String x = s.split(",")[0];
                String y = s.split(",")[1];
                String z = s.split(",")[2];
                return new Coordinate(x, y, z);
            }
        });
复制代码

自己写了一下demo,并且分析了一下这种写法的优势和场景;

1. 可以将很多场景下通用的逻辑抽象出来  ,  将业务代码写在业务层:

  假设我们在做地图服务的服务端,会接收到不同的客户端给我们传来的不同参数,这些参数的格式都不统一

  有的传的多几何坐标  x1,y1;x2,y2;...  。 有的是  x1 y1;x2 y2;...  等等

 

 通常处理:如果不用java8特性,我们可能会对每一种规范都单独写一个方法。而且 还要写两个service接口。

   List<Coordinate> methodA(List<String> parms){

     List<Coordinate> list = Lists.newArrayList<>();

     for(String coord : parms){

        String[] split = coord.split(";");

        for(String c : split){

           String x = c.split(",")[0];

   String y = c.split(",")[1];

            list.add(new Coordinate(x,y));

  }

     }

    return  coordinate

}

 

List<Coordinate> methodB(List<String> parms){

     List<Coordinate> list = Lists.newArrayList<>();

     for(String coord : parms){

        String[] split = coord.split(";");

        for(String c : split){

           String x = c.split(" ")[0];

   String y = c.split(" ")[1];

            list.add(new Coordinate(x,y));

  }

     }

    return  coordinate

}

 

使用java8:

只需要写一个接口:

public <T> List<Coordinate> simplfy(Collection<T> lnglatList , Function<T ,Coordinate> transformer);
public <T> List<Coordinate> simplfy(Collection<T> lnglatList, Function<T, Coordinate> transformer) {
        List<Coordinate> rs = new ArrayList<>();
        for (T lnglat : lnglatList){
            Coordinate Coordinate = transformer.apply(lnglat);
            rs.add(Coordinate);
        }
        return rs;
    }

 

剩下的就是在各自的业务中调用:

A使用:

List<Coordinate> rs1 = service.simplfy(set, new Function<String, Coordinate>() {
            @Override
            public Coordinate apply(String s) {
                String x = s.split(",")[0];
                String y = s.split(",")[1];return new Coordinate(x, y);
            }
        });

B使用:

List<Coordinate> rs1 = service.simplfy(set, new Function<String, Coordinate>() {
            @Override
            public Coordinate apply(String s) {
                String x = s.split(" ")[0];
                String y = s.split(" ")[1];
                return new Coordinate(x, y);
            }
        });

 

优势:节约冗余的代码,优化JVM,减少方法区占用内存空间




 

     

posted @   蔡徐坤1987  阅读(1210)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示