答案:通过设计Car和ParkingLot类,使用HashMap管理车辆信息,实现车辆入场、离场计费、防止重复入场及查询在场车辆功能,结合LocalDateTime处理时间,完成一个基于Java的停车场管理系统。

用Java实现一个停车场管理系统,核心在于对象的设计、集合的使用以及业务逻辑的控制。这个项目能很好地锻炼面向对象编程能力、集合操作和流程控制技巧。下面从需求分析到代码实现一步步说明如何构建这样一个系统。
1. 系统需求与对象设计
假设我们要实现一个简单的停车场管理系统,具备以下功能:
- 车辆进入时记录车牌号、进入时间
- 车辆离开时计算停车费用(按小时计费)
- 查看当前在场车辆列表
- 防止重复入场
根据这些需求,我们需要设计两个主要类:
Car类:表示一辆车,包含车牌号和入场时间。ParkingLot类:管理车辆的进出和费用计算。
2. Car类定义
Car类用于封装车辆的基本信息:
立即学习“Java免费学习笔记(深入)”;
import java.time.LocalDateTime;public class Car { private String licensePlate; private LocalDateTime entryTime;
public Car(String licensePlate, LocalDateTime entryTime) { this.licensePlate = licensePlate; this.entryTime = entryTime; } public String getLicensePlate() { return licensePlate; } public LocalDateTime getEntryTime() { return entryTime; } @Override public String toString() { return "车牌: " + licensePlate + ", 入场时间: " + entryTime; }}
3. ParkingLot类实现逻辑控制
ParkingLot类使用HashMap存储车辆信息,便于通过车牌快速查找。同时设置每小时收费标准。
import java.time.LocalDateTime; import java.time.temporal.ChronoUnit; import java.util.HashMap; import java.util.Map;public class ParkingLot { private Map
parkedCars; private double ratePerHour; // 每小时费用 public ParkingLot(double ratePerHour) { this.parkedCars = new HashMap<>(); this.ratePerHour = ratePerHour; } // 车辆入场 public void enter(Car car) { String plate = car.getLicensePlate(); if (parkedCars.containsKey(plate)) { System.out.println("车辆 " + plate + " 已在场内,禁止重复入场!"); return; } parkedCars.put(plate, car); System.out.println("车辆 " + plate + " 成功入场。"); } // 车辆离场并计算费用 public void leave(String licensePlate) { Car car = parkedCars.remove(licensePlate); if (car == null) { System.out.println("该车辆未在场内,无法离场。"); return; } LocalDateTime exitTime = LocalDateTime.now(); long minutes = ChronoUnit.MINUTES.between(car.getEntryTime(), exitTime); long hours = (minutes + 59) / 60; // 向上取整为小时数 double fee = hours * ratePerHour; System.out.printf("车辆 %s 离场,停车时长: %d 分钟 (%d 小时),费用: %.2f 元%n", licensePlate, minutes, hours, fee); } // 查看当前在场车辆 public void listCurrentCars() { if (parkedCars.isEmpty()) { System.out.println("当前无车辆在场。"); return; } System.out.println("当前在场车辆:"); parkedCars.values().forEach(System.out::println); }}
4. 测试与运行示例
编写主类进行测试:
import java.time.LocalDateTime;public class ParkingSystemTest { public static void main(String[] args) { ParkingLot lot = new ParkingLot(5.0); // 每小时5元
Car car1 = new Car("京A12345", LocalDateTime.now().minusHours(2)); Car car2 = new Car("沪B66666", LocalDateTime.now().minusMinutes(30)); lot.enter(car1); lot.enter(car2); lot.listCurrentCars(); lot.leave("京A12345"); lot.leave("沪B66666"); lot.listCurrentCars(); }}
输出结果大致如下:
车辆 京A12345 成功入场。 车辆 沪B66666 成功入场。 当前在场车辆: 车牌: 京A12345, 入场时间: 2025-04-05T10:00:00 车牌: 沪B66666, 入场时间: 2025-04-05T11:30:00 车辆 京A12345 离场,停车时长: 120 分钟 (2 小时),费用: 10.00 元 车辆 沪B66666 离场,停车时长: 30 分钟 (1 小时),费用: 5.00 元 当前无车辆在场。基本上就这些。通过合理设计对象和使用集合类(如HashMap),再配合时间处理和条件判断,就能实现一个结构清晰、易于扩展的停车场管理系统。后续可加入图形界面、数据库持久化或车位数量限制等功能进一步提升项目复杂度。










