Collections.swap用于交换List中两索引处元素,需确保列表可修改且索引有效,否则抛出异常。
在Java中,Collections.swap 是一个静态方法,用于交换集合中指定两个位置的元素。它适用于所有实现了 List 接口的集合类,比如 ArrayList、LinkedList 等。这个方法不需要手动创建临时变量来完成交换,简化了代码逻辑。
该方法定义在 java.util.Collections 工具类中,语法如下:
public static void swap(List> list, int i, int j)参数说明:
执行后,索引 i 和 j 处的元素会被互换。
示例代码:
ListSystem.out.println("交换前: " + names); // [Alice, Bob, Charlie]
Collections.swap(names, 0, 2);
System.out.println("交换后: " + names); // [Charlie, Bob, Alice]
这个方法常用于需要调整元素顺序的场景,例如排序算法中的元素交换、随机打乱顺序(类似洗牌算法)等。
需要注意以下几点:
避免异常的建议:
if (i >= 0 && j >= 0 && i Collections.swap(list, i, j);Collections.swap 的内部实现非常简洁。它本质上是通过 get 和 set 方法完成的:
public static void swap(List> list, int i, int j) {
List l = list;这行代码利用了 set 方法的返回值特性:set(index, element) 会返回原来位于该位置的元素。因此可以在一行内完成无临时变量的交换。
可以结合 Random 类使用 swap 来打乱列表顺序:
Listfor (int i = numbers.size() - 1; i > 0; i--) {
int j = rand.nextInt(i + 1);
Collections.swap(numbers, i, j);
}
System.out.println("打乱后: " + numbers);
基本上就这些。Collections.swap 提供了一种简洁安全的方式来交换集合中两个位置的元素,避免了手动编写交换逻辑的繁琐和出错可能。只要注意索引边界和集合可变性,就能高效使用。