List、Set、Map、数组之间各种转换

刚学Java不久的时候,接到一个电面,然后问了一些java的知识,比如说Java的编码,Unicode等,但是最让我蛋疼的是怎么吗map转为set,那个时候对集合用的很少,对集合不是特别了解,map还知道,set就蒙了,然后转为set更蒙了,觉得应该有API提供吧,但是不知道怎么说。后来我一直下来再查这个问题,查到了,但是没有实践过,今天我就来一发代码。

List转Set                                                                                   

Set set = new HashSet(new ArrayList());

Set转List                                                                                   

List list = new ArrayList(new HashSet());

数组转为List                                                                                

List arr = Arrays.asList("1", "2", "3");
//或者
String[] arr = {"1", "2"};
List list = Arrays.asList(arr);

数组转为Set                                                                                 

int[] arr = { 1, 2, 3 };
Set set = new HashSet(Arrays.asList(arr));

Map的值转化为List                                                                      

List list = new ArrayList(map.values());

Map的值转化为Set                                                                       

Set set = new HashSet(map.values());

List转数组                                                                                   

List list = Arrays.asList("a","b");
String[] arr = (String[])list.toArray(new String[list.size()]);

代码                                                                                         

public class listsetmao {
    private static List<String> arrayList;
    private static Map<String, String> hashMap;
    private static Set<String> hashSet;
    private static String[] arr = {"11oneone","22twotwo"};
    public static void main(String[] args) {
        /*
         * //list转set initList(); Set<String> set = new
         * HashSet<String>(arrayList);
         * System.out.println("arrayList.toString()--->"+set.toString());
         * System.out.println("set.toString()--->"+set.toString());
         */
        /*
         * //set转list initSet(); List<String> list = new
         * ArrayList<String>(hashSet);
         * System.out.println("hashSet.toString()--->"+hashSet.toString());
         * System.out.println("list.toString()--->"+list.toString());
         */
        /*
        // 数组转为list
        List<String> list = Arrays.asList(arr);
        System.out.println("list.toString()--->"+list.toString());
        */
        /*
        //数组转set
        Set set = new HashSet<>(Arrays.asList(arr));
        System.out.println("set.toString()--->"+set.toString());
        */
        /*
        //map的值转为list
        initMap();
        List<String> list = new ArrayList<String>(hashMap.values());
        System.out.println("list.toString()--->"+list.toString());
        */
        /*
        //map的值转为set
        initMap();
        Set<String> set = new HashSet<String>(hashMap.values());
        System.out.println("set.toString()--->"+set.toString());
        */
        /*
        //map的key转为set
        initMap();
        Set<String> set = new HashSet<String>(hashMap.keySet());
        System.out.println("set.toString()--->"+set.toString());
        */
        //list转数组
        initList();
        String[] arr1 = (String[])arrayList.toArray(new String[arrayList.size()]);
        System.out.println("Arrays.toString(arr1)--->"+Arrays.toString(arr1));
    }
    public static void initList() {
        arrayList = new ArrayList<String>();
        arrayList.add("1");
        arrayList.add("2");
        arrayList.add("3");
        arrayList.add("4");
    }
    public static void initMap() {
        hashMap = new HashMap<String, String>();
        hashMap.put("one", "one1");
        hashMap.put("two", "two2");
        hashMap.put("three", "three3");
    }
    public static void initSet() {
        hashSet = new HashSet<String>();
        hashSet.add("1one");
        hashSet.add("2two");
        hashSet.add("3three");
        hashSet.add("4four");
        hashSet.add("5five");
    }

}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏cmazxiaoma的架构师之路

Java数据结构和算法(1)--自定义一个数组类和动态数组类

1604
来自专栏我的技术专栏

数据结构图文解析之:树的简介及二叉排序树C++模板实现.

1274
来自专栏Android机动车

数据结构——遍历二叉树

二叉树的遍历:是指从根结点出发,按照某种次序依次访问二叉树中的所有结点,使得每个结点被访问一次且仅被访问一次。

881
来自专栏Java后端技术

一道面试题引发的思考

为什么呢?那么我们怎么来发现它背后的秘密呢?答案只有一个:那就是通过源码来解惑(ArrayList部分源码)。

690
来自专栏拭心的安卓进阶之路

Java 集合深入理解(12):古老的 Vector

今天刮台风,躲屋里看看 Vector ! 都说 Vector 是线程安全的 ArrayList,今天来根据源码看看是不是这么相...

2867
来自专栏拭心的安卓进阶之路

Java 集合深入理解(7):ArrayList

今天心情有点美丽,学学 ArrayList 放松下吧! 什么是 ArrayList ? ? ArrayList 是 Java 集合框架中 List接口 的一个实...

2297
来自专栏武培轩的专栏

ArrayList源码解析(JDK1.8)

1 package java.util; 2 3 import sun.misc.SharedSecrets; 4 5 imp...

3005
来自专栏Hongten

ArrayList, LinkedList, Vector - dudu:史上最详解

ArrayList, LinkedList, Vector - dudu:史上最详解

933
来自专栏Android机器圈

数据结构与算法 -- 二叉树链式详解((非)/递归遍历,叶子个数,深度计算)

PS:树型结构是一种重要的非线性数据结构,教科书上一般都是树与二叉树,由此可见,树和二叉树是有区别和联系的,网上有人说二叉树是树的一种特殊形式,但经过查资料,树...

945
来自专栏博岩Java大讲堂

Java集合--List源码

2514

扫码关注云+社区

领取腾讯云代金券