
在软件开发中,我们经常面临需要从一个集合中筛选并移动元素到另一个集合的场景,尤其是在处理动态数据时。以车辆入库为例,我们的目标是将一个 vehicles 列表中待停放的车辆,根据一系列严格的条件,将其分配到 garage 列表中合适的车库空间中,直到 vehicles 列表为空或无法再停放任何车辆。
这个过程的挑战在于,当我们在遍历 vehicles 列表时,如果成功停放一辆车,就需要将其从 vehicles 列表中移除。在迭代过程中直接修改正在遍历的列表,是一个常见的陷阱,可能导致元素被跳过、程序行为异常,甚至抛出 ConcurrentModificationException。
原始的尝试代码通过复杂的嵌套循环和 i-- 操作来尝试解决这个问题,但其逻辑可能不够清晰,且容易出错。一个更简洁、更健壮的解决方案是必要的。
在 Java 等语言中,当使用传统的 for 循环或增强 for 循环遍历 ArrayList 等列表时,直接调用 list.remove(index) 或 list.remove(object) 可能会导致意外行为:
正向迭代 (for (int i = 0; i < list.size(); i++)) 并移除元素: 如果 list.remove(i) 被调用,当前索引 i 处的元素被移除,列表后续元素会向前移动一个位置。下一次循环 i 增加,导致原先在 i+1 位置的元素(现在在 i 位置)被跳过。
增强 for 循环 (for (Object item : list)) 并移除元素: 这种方式在循环体内直接调用 list.remove() 会立即抛出 ConcurrentModificationException,因为增强 for 循环内部使用了迭代器,而迭代器不允许在迭代过程中通过集合自身的方法修改集合结构。
反向迭代 (for (int i = list.size() - 1; i >= 0; i--)) 并移除元素: 这是相对安全的做法,因为移除元素不会影响尚未遍历到的前面部分的索引。原始尝试代码中使用了类似 i-- 的逻辑,正是为了处理这种情况。
为了编写出既安全又易于理解的代码,我们通常会采用以下两种策略:
为了安全且高效地完成车辆入库任务,我们将采用结合 while 循环和 Iterator 的策略。while 循环确保我们持续尝试停车,直到所有车辆都被处理或无法再停车。Iterator 则保证了在遍历 vehicles 列表并移除已停车车辆时的线程安全和逻辑正确性。
停车的核心逻辑体现在以下复合条件中:
if (currentGarage.getSpace() == currentVehicle.getSpace() && // 车库空间与车辆所需空间匹配
    currentGarage.garageRequest(currentVehicle.getvehiclesType()) && // 车库接受该车辆类型
    currentGarage.getLimit() > 0) // 车库仍有空余容量这三个条件必须同时满足,车辆才能被停放。getLimit() 方法应返回车库当前剩余的可用空间。
以下是实现上述健壮解决方案的 Java 示例代码:
import java.util.ArrayList;
import java.util.List;
import java.util.Iterator;
// 假设 Vehicle 和 Garage 类已定义,并包含必要的属性和方法
public class VehicleParkingSystem {
    private List<Vehicle> vehicles; // 待停放车辆列表
    private List<Garage> garage;     // 可用车库列表
    public VehicleParkingSystem(List<Vehicle> vehicles, List<Garage> garage) {
        this.vehicles = vehicles;
        this.garage = garage;
    }
    /**
     * 尝试将所有待停放车辆停入合适的车库。
     */
    public void parkAllVehicles() {
        System.out.println("--- 开始停车过程 ---");
        // 循环直到所有车辆都被处理完毕,或者没有更多车辆可以被停放
        while (!vehicles.isEmpty()) {
            boolean vehiclesParkedInCurrentPass = false; // 标记本次循环是否有车辆被成功停放
            // 使用 Iterator 安全地遍历和移除元素
            Iterator<Vehicle> vehicleIterator = vehicles.iterator();
            while (vehicleIterator.hasNext()) {
                Vehicle currentVehicle = vehicleIterator.next();
                boolean vehicleFoundSpot = false; // 标记当前车辆是否找到车位
                // 遍历所有车库,尝试为当前车辆找到一个合适的位置
                for (Garage currentGarage : garage) {
                    // 检查所有停车条件:
                    // 1. 车库空间与车辆所需空间匹配
                    // 2. 车库接受该车辆类型
                    // 以上就是动态列表元素条件转移与高效处理:以车辆入库为例的详细内容,更多请关注php中文网其它相关文章!
 
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
 
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号