可变参数以及不可变集合

可变参数:

格式:

java 复制代码
public class ArgsDemo {
    public static void main(String[] args) {

        System.out.println(getSum(1,2,3,4,5));
    }

    //可变参数
    public static int getSum(int...args){
        int sum = 0;
        for (int arg : args) {
            sum += arg;
        }
        return sum;
    }
}

可变参数的形参中只能写一个可变参数

Collections集合类

java.util.Collections:是集合工具类

作用:Collections不是集合,而是集合工具类

常用API:

图来自黑马程序员网课

java 复制代码
package com.lazyGirl.collectionsdemo;

import java.util.ArrayList;
import java.util.Collections;

public class Demo1 {
    public static void main(String[] args) {

        ArrayList<String> list = new ArrayList<>();
        Collections.addAll(list,"abc","bcd","quen");
        System.out.println(list);

        Collections.shuffle(list);
        System.out.println(list);

        
    }
}

输出:

java 复制代码
package com.lazyGirl.collectionsdemo;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Random;

public class Demo2 {
    public static void main(String[] args) {

        ArrayList<String> list = new ArrayList<>();

        Collections.addAll(list, "a", "b", "c");


        ArrayList<String> list1 = new ArrayList<>();
        Random rand = new Random();

        for (int i = 0; i < 10; i++) {
            int count = list.size();
            for (int j = 0; j < count; j++) {
                int index = rand.nextInt(list.size());
                String name = list.remove(index);
                list1.add(name);
                System.out.println(name);
            }

            list.addAll(list1);
            list1.clear();
        }


    }
}

不可变集合

应用场景:

不想让别人修改集合中的内容

书写格式:

图来自黑马程序员网课

java 复制代码
package com.lazyGirl.immytable;

import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;

public class Demo1 {
    public static void main(String[] args) {
        List<String> list = List.of("zs","ls","ww","zl");
//        System.out.println(list.get(0));

        for (String s : list) {
            System.out.println(s);
        }

//        System.out.println(list.remove("zs"));
//        System.out.println(list.add("aaa"));

        Set<String> set = Set.of("zs","ls","ww","zl");//保证元素唯一
        for (String s : set) {
            System.out.println(s);
        }
        System.out.println("----");
//        System.out.println(set.add("aaa"));

        //键值对数量小于10
        Map<String,String> map1 = Map.of("a","b","c","d","e","f");
        for (String s : map1.keySet()) {
            System.out.println(s + " " + map1.get(s));
        }
        System.out.println("----");

        Map<String,String> map2 = Map.copyOf(map1);
//        System.out.println(map2);
//        map2.put("e","u");


    }
}

方法细节:

List:直接用

Set:元素不能重复

Map:元素不能重复,键值对数量最多为10个,超过10个用ofEntryies方法;或者Jdk>10 使用copyOf方法

相关推荐
阿巴~阿巴~2 分钟前
蓝桥杯 C/C++ 组历届真题合集速刷(一)
c语言·c++·算法·蓝桥杯
_x_w8 分钟前
【12】数据结构之基于线性表的排序算法
开发语言·数据结构·笔记·python·算法·链表·排序算法
有诺千金11 分钟前
深入理解 Spring Boot 的@AutoConfiguration注解
java·spring boot·后端
代码吐槽菌12 分钟前
基于SpringBoot的律师事务所案件管理系统【附源码】
java·数据库·spring boot·后端·毕业设计
flzjkl18 分钟前
【源码】【Java并发】【ReentrantLock】适合中学者体质的ReentrantLock源码阅读
java·后端
freejackman21 分钟前
Java 环境配置
java·后端·java ee
瀚海澜生23 分钟前
链表系列入门指南(二):吃透这几题,链表解题不再难
后端·算法
爱编码的傅同学28 分钟前
数据结构(五)——AVL树(平衡二叉搜索树)
数据结构·算法
Bonnie_121529 分钟前
02-redis-数据结构实现原理
数据结构·redis·算法
bug菌38 分钟前
领导安排我一小时实现一个导出功能,我竟用@Excel注解两分钟搞定!🫠
java·后端·spring