JavaSE——集合框架二(1/6)-前置知识-可变参数、Collections工具类

目录

可变参数

Collections工具类

Collections的常用静态方法

实例演示


可变参数

可变参数

  • 就是一种特殊形参,定义在方法、构造器的形参列表里,格式是:数据类型...参数名称

可变参数的特点和好处

  • 特点:可以不传数据给它;可以传一个或者同时传多个数据给它;也可以传一个数组给它。
  • 好处:常常用来灵活的接收数据。
java 复制代码
import java.util.Arrays;

public class ParamTest {
    public static void main(String[] args) {
        test();                     //不传数据
        test(10);            //传输一个数据
        test(10,20);         //传输多个数据
        test(new int[]{10,20,30});  //传输一个数组
    }
    public static void test(int...nums){
        //可变参数在方法内部,本质就是一个数组
        System.out.println(nums.length);
        System.out.println(Arrays.toString(nums));
        System.out.println("---------------------");
    }
}

运行结果:

可变参数的注意事项

  • 可变参数在方法内部就是一个数组
  • 一个形参列表中可变参数只能有一个
  • 可变参数必须放在形参列表的最后面

Collections工具类

  • 和Collection区分开来,Collections是一个用来操作集合的工具类。

Collections的常用静态方法

方法名称 说明
public static<T> boolean addAll(Collection<? super T>c,T...elements) 给集合批量添加元素
public static void shuffle(List<?> list) 打乱List集合中的元素顺序
public static<T> void sort(List<T>list) 对List集合中的元素进行升序排序
public static<T> void sort(List<T> list, Comparator<? super T>c) 对List集合中元素,按照比较器对象指定的规则进行排序

实例演示

给集合批量添加元素、打乱List集合中的元素顺序

java 复制代码
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class CollectionsTest {
    public static void main(String[] args) {
        //1.public static<T> boolean addAll(Collection<? super T>c,T...elements)
        //给集合批量添加元素
        List<String> names = new ArrayList<>();
        Collections.addAll(names,"张三","王五","李四","张麻子");
        System.out.println(names);

        //2.public static void shuffle(List<?> list)
        //打乱List集合中的元素顺序
        Collections.shuffle(names);
        System.out.println(names);
    }
}

运行结果:

排序部分一

java 复制代码
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class CollectionsTest {
    public static void main(String[] args) {
        //3.public static<T> void sort(List<T>list)
        //对List集合中的元素进行升序排序
        List<Integer> list = new ArrayList<>();
        Collections.addAll(list,3,5,2);
        Collections.sort(list);
        System.out.println(list);
    }
}

运行结果:

当给对象排序时,就需要重写对象内部的compareTo方法:

java 复制代码
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class CollectionsTest {
    public static void main(String[] args) {
        List<Student> students = new ArrayList<>();
        students.add(new Student("至尊宝",26,165.5));
        students.add(new Student("蜘蛛精",23,169.7));
        students.add(new Student("牛魔王",22,183.5));
        students.add(new Student("紫霞",22,169.8));
        Collections.sort(students);   //自定义排序:按年龄升序排序
        System.out.println(students);
    }
}

运行结果:(输出结果重写了toString方法)

排序部分二

java 复制代码
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class CollectionsTest {
    public static void main(String[] args) {
        List<Student> students = new ArrayList<>();
        students.add(new Student("至尊宝",26,165.5));
        students.add(new Student("蜘蛛精",23,169.7));
        students.add(new Student("牛魔王",22,183.5));
        students.add(new Student("紫霞",22,169.8));

        //4.public static<T> void sort(List<T> list, Comparator<? super T>c)
        //对List集合中元素,按照比较器对象指定的规则进行排序
        Collections.sort(students, new Comparator<Student>() {
            @Override
            public int compare(Student o1, Student o2) {
                return Double.compare(o1.getHeight(),o2.getHeight());
            }
        });         //如果两种自定义排序都存在,则就近使用这个排序规则
        System.out.println(students);
    }
}

运行结果:


END


学习自:黑马程序员------JavaSE课程

相关推荐
budingxiaomoli几秒前
多线程(一)
java·开发语言·jvm·java-ee
CandyU22 分钟前
UE5 C++ 进阶学习 小知识点 —— 01 - 本地化语言
学习·ue5
ysa05103015 分钟前
虚拟位置映射(标签鸽
数据结构·c++·笔记·算法
Yue丶越20 分钟前
【C语言】深入理解指针(二)
c语言·开发语言·数据结构·算法·排序算法
m0_7482480225 分钟前
C++中的位运算符:与、或、异或详解
java·c++·算法
介一安全25 分钟前
从 0 到 1 玩转 2025 最新 WebGoat 靶场:环境搭建 + 全关卡漏洞解析(超级详细)
java·web安全·网络安全·靶场
web安全工具库25 分钟前
Linux进程的:深入理解子进程回收与僵尸进程
java·linux·数据库
沐浴露z26 分钟前
详解【限流算法】:令牌桶、漏桶、计算器算法及Java实现
java·算法·限流算法
武陵悭臾43 分钟前
Python应用开发学习: Pygame 中实现数字水平靠右对齐和垂直靠底对齐
python·学习·程序人生·游戏·个人开发·学习方法·pygame
Tonya431 小时前
测开学习DAY26
学习