Java与Scala创建List与Map的实现方式

 更新时间:2021年10月11日 09:18:21   作者:骑码找马  
这篇文章主要介绍了Java与Scala创建List与Map的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Java与Scala创建List与Map

//Java
List<String> languages = new ArrayList<>(); 
Map<String, Class> mapFields = new HashMap();
    
//Scala 
val languages = new util.ArrayList[String]    
val mapFields=new util.HashMap[String, Class]

Java自定义map与scala map对比

1. 背景

  • 在学习scala过程中,不可避免需要将java与scala对比,本文就是基于scala的map,使用java进行实现
  • jdk1.8中,引入了Stream、lambda表达式,这让java也可以支持函数式编程。

2. java代码

2.1 自定义实现的map

package com.doit.udf;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
/**
 * @author hulc
 * @slogan: just do it
 * @date 2020/9/13 21:16
 */
public class UserDefineFunc {
    public static void main(String[] args) {
        test1();
    }
    private static void test1() {
        // 使用java来实现scala中针对集合的map、reduce、filter函数的效果
        List<Integer> list = new ArrayList<>();
        list.addAll(Arrays.asList(1,2,3,4,5,6,7,8,9));
        MyList<Integer> integers = new MyList<Integer>(list);
        // 使用匿名内部类方式进行自定义map方法调用
        List<Object> list1 = integers.map(new MyMapFunction() {
            @Override
            public <String, K> String map(K k) {
                if (k instanceof Integer) {
                    Integer i = (Integer) k;
                    i += 10;
                    return (String) ("" + i);
                }
                return null;
            }
        });
        for (Object o : list1) {
            System.out.println(o.toString());
        }
    }
}
class MyList<T> extends ArrayList<T> {
    private List<T> words;
    public MyList(List<T> words) {
        this.words = words;
    }
    public List<Object> map(MyMapFunction function) {
        List<Object> ts = new ArrayList<>();
        for (T t : words) {
            Object map = function.map(t);
            ts.add(map);
        }
        return ts;
    }
}
interface MyMapFunction {
    // map就是一个转换函数,输入一个K,转换为一个T
    <T, K> T map(K k);
}

2.2 使用jdk的Sream进行函数式处理

private static void test2() {
        List<Integer> list = new ArrayList<>();
        list.addAll(Arrays.asList(1,2,3,4,5,6,7,8,9));
        // 将list转换为Stream,再进行处理,这时候就可以使用函数式进行处理
        Stream<Integer> integerStream = list.stream();
        Stream<String> stringStream = integerStream.map(w -> {
            w += 10;
            return "" + w;
        });
        // 遍历打印
        Object[] toArray = stringStream.toArray();
        for (Object o : toArray) {
            System.out.println(o.toString());
        }
    }

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • springboot中关于classpath:路径使用及说明

    springboot中关于classpath:路径使用及说明

    这篇文章主要介绍了springboot中关于classpath:路径使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • Java中的TreeSet集合解析

    Java中的TreeSet集合解析

    这篇文章主要介绍了Java中的TreeSet集合解析,  TreeSet是一个有序的集合,基于TreeMap实现,支持两种排序方式:自然排序和定制排序,
    TreeSet是非同步的,线程不安全的,需要的朋友可以参考下
    2023-09-09
  • 完美解决Spring声明式事务不回滚的问题

    完美解决Spring声明式事务不回滚的问题

    下面小编就为大家带来一篇完美解决Spring声明式事务不回滚的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 使用SpringBoot+Prometheus+Grafana实现可视化监控

    使用SpringBoot+Prometheus+Grafana实现可视化监控

    本文主要给大家介绍了如何使用Spring actuator+监控组件prometheus+数据可视化组件grafana来实现对Spring Boot应用的可视化监控,文中有详细的代码供大家参考,具有一定的参考价值,需要的朋友可以参考下
    2024-02-02
  • 基于springcloud异步线程池、高并发请求feign的解决方案

    基于springcloud异步线程池、高并发请求feign的解决方案

    这篇文章主要介绍了基于springcloud异步线程池、高并发请求feign的解决方案,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • Java switch case语句举例详解

    Java switch case语句举例详解

    这篇文章主要给大家介绍了关于Java switch case语句举例详解的相关资料,switch case语句是一种流程控制语句,用于根据不同的条件执行不同的代码块,需要的朋友可以参考下
    2023-10-10
  • Java的split方法使用详解

    Java的split方法使用详解

    这篇文章主要详细介绍了Java的split方法使用说明,十分的细致全面,有需要的小伙伴可以参考下。
    2015-07-07
  • java启动jar包修改JVM默认内存问题

    java启动jar包修改JVM默认内存问题

    这篇文章主要介绍了java启动jar包修改JVM默认内存问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • idea更改默认缓存位置的步骤详解

    idea更改默认缓存位置的步骤详解

    在idea使用中,会产生大量的缓存,一般默认存放在C盘里面,会加大C盘的储存负担,如果C盘足够大,可以不考虑更改idea的缓存位置,所以本文小编给如何更改idea默认缓存位置,文中通过图文结合介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • 解析springboot包装controller返回值问题

    解析springboot包装controller返回值问题

    这篇文章主要介绍了springboot包装controller返回值问题,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-12-12

最新评论