停车位 车辆
假设,我们现在有个vechice对象,和一个parking lot对象 。 现在需要描述一个功能,停车, 这需要把车和parking lot对象起来。请问,这部分逻辑,放在哪个对象好? 有什么规则呢
在面向对象设计中,停车(park)这个功能涉及两个对象:车辆(vehicle)和停车场(parking lot)。一般有以下几种设计选择:
-
放在 ParkingLot 对象里:
停车场负责管理停车逻辑,比如检查空位、登记车辆等。通常推荐将“停车”方法(如 park(vehicle))放在 ParkingLot 类中,因为停车场拥有资源(车位),负责分配和管理。 -
放在 Vehicle 对象里:
车辆可以有一个 park(parkingLot) 方法,但实际操作还是由停车场完成。车辆只是请求停车,具体实现还是 ParkingLot。 -
独立的服务类:
如果逻辑复杂,可以有一个 ParkingService 类,负责协调车辆和停车场。
【推荐规则】
- 谁拥有资源,谁负责管理。停车场拥有车位,负责分配和登记,所以“停车”逻辑应放在 ParkingLot。
- Vehicle 只持有自己的状态,不负责管理停车场资源。
- 如果涉及多个停车场或复杂业务,可用服务类协调。
总结:
“停车”逻辑一般放在 ParkingLot 对象里,实现 park(vehicle) 方法。这样职责清晰,易于维护和扩展。