Collections.swap用于交换List中两索引处元素,需确保列表可修改且索引有效,否则抛出异常。

在Java中,Collections.swap 是一个静态方法,用于交换集合中指定两个位置的元素。它适用于所有实现了 List 接口的集合类,比如 ArrayList、LinkedList 等。这个方法不需要手动创建临时变量来完成交换,简化了代码逻辑。
1. Collections.swap 方法的基本用法
该方法定义在 java.util.Collections 工具类中,语法如下:
public static void swap(List> list, int i, int j)参数说明:
- list:要操作的列表
- i:第一个元素的索引
- j:第二个元素的索引
执行后,索引 i 和 j 处的元素会被互换。
立即学习“Java免费学习笔记(深入)”;
示例代码:
Listnames.add("Alice");
names.add("Bob");
names.add("Charlie");
System.out.println("交换前: " + names); // [Alice, Bob, Charlie]
Collections.swap(names, 0, 2);
System.out.println("交换后: " + names); // [Charlie, Bob, Alice]
2. 使用场景与注意事项
这个方法常用于需要调整元素顺序的场景,例如排序算法中的元素交换、随机打乱顺序(类似洗牌算法)等。
需要注意以下几点:
- 集合必须是可修改的。如果传入的是不可变列表(如通过 Arrays.asList 创建且底层数组固定),调用 swap 会抛出 UnsupportedOperationException。
- 索引 i 和 j 必须在集合的有效范围内(0 到 size()-1),否则会抛出 IndexOutOfBoundsException。
- 如果 i 和 j 相同,方法不会报错,但也不会有任何实际操作。
避免异常的建议:
if (i >= 0 && j >= 0 && i Collections.swap(list, i, j);}
3. 内部实现原理简析
Collections.swap 的内部实现非常简洁。它本质上是通过 get 和 set 方法完成的:
public static void swap(List> list, int i, int j) {final List l = list;
l.set(i, l.set(j, l.get(i)));
}
这行代码利用了 set 方法的返回值特性:set(index, element) 会返回原来位于该位置的元素。因此可以在一行内完成无临时变量的交换。
4. 实际应用示例:实现简单洗牌算法
可以结合 Random 类使用 swap 来打乱列表顺序:
ListRandom rand = new Random();
for (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 提供了一种简洁安全的方式来交换集合中两个位置的元素,避免了手动编写交换逻辑的繁琐和出错可能。只要注意索引边界和集合可变性,就能高效使用。










