如何实现用Java编写程序,设计一个模拟电梯运行的类

实现代码如下:public class ElevatorModel implenent ElevatorModelListener{ElevatorShaft elevatorShaft;//电梯车箱Floor firstFloor;Floor secondFloor;public void addPerson(Person person);//实现ElevatorMo
摘要由CSDN通过智能技术生成

实现代码如下:

public class ElevatorModel implenent ElevatorModelListener{

ElevatorShaft elevatorShaft;//电梯车箱
Floor firstFloor;
Floor secondFloor;

public void addPerson(Person person);
//实现ElevatorModelListener接口的所有方法

}

public abstract class Location{
String locationName;//可能占据的三个位置firstFloor; secondFloor;elevator中的其中一个位置。

public Button getButton();
public Door getDoor();
}

public class Floor extends Location{
public Floor(String firstFloor,String secondFloor);

public Button getButton();//具体实现
public Door getDoor();//具体实现
public ElevatorShaft getElevatorShaft();
}

public class Door implenent ElevatorMoveListener{
boolean open;//门是开的关的
public void openDoor();//开门
public viod clossDoor();//关门
}

public class Button implenent Eleva
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
用面向对象方法和面向对象程序设计语言,实现满足下述要求的一个高层建筑电梯活动 仿真程序。 问题域概述 某国际展览中心共 40 层,设有载客电梯10 部(用E0~E9 标识)。 限定条件 (1) 电梯运行规则是: E0、E1:可到达每层。 E2、E3:可到达1、25~40 层。 E4、E5:可到达1~25 层。 E6、E7:可到达1、2~40 层中的偶数层。 E8、E9:可到达1~39 层中的奇数层。 (2) 每部电梯的最大乘员量均为K 人(K 值可以根据仿真情况在10~18 人之间确定)。 (3) 仿真开始时,各电梯随机地处于其符合运行规则的任意一层,为空梯。 (4) 仿真开始后,有N 人(0<N<1000)在M 分钟(0<M<10)内随机地到达该国际 展览中心的1 层,开始乘梯活动。 (5) 每位乘客初次所要到达的楼层是随机的,令其在合适的电梯处等待电梯到来。 (6) 每位乘客乘坐合适的电梯到达指定楼层后,随机地停留10-120 秒后,再随机 地去往另一楼层,依此推,当每人乘坐过L 次(每人的L 值不同,在产生乘客时随机地 在1~10 次之间确定)电梯后,第L+1 次为下至底层并结束乘梯行为。到所有乘客结束乘梯 行为时,本次仿真结束。 (7) 电梯运行速度为S 秒/层(S 值可以根据仿真情况在1~5 之间确定),每人上下时 间为T 秒(T 值可以根据仿真情况在2~10 之间确定)。 (8) 电梯运行的方向由先发出请求者决定,不允许后发出请求者改变电梯的当前运 行方向,除非是未被请求的空梯。 (9) 当某层有乘客按下乘梯电钮时,优先考虑离该层最近的、满足条件(8)、能够 最快到达目标层的电梯。 (10) 不允许电梯超员。 开发结果的行为特征 (1) 产生事件的周期为1 秒,每次可产生0 个或多个事件。 (2) 各随机事件由互不相关的伪随机数发生器决定。 (3) 设计一个易于理解的界面,动态显示各梯的载客与运行情况,动态显示各楼层 的人员停留情况与要求乘梯情况;动态显示从仿真开始到目前的时间。 (4) 显示时用应表示出不同的乘客及其当前所要求去往的楼层。例如,12-32 表示标 识为12 的乘客要求去往32 层。 (5) 统计各梯的运行与空闲时间;统计各人发出乘梯要求后的等待时间;仿真结束 后显示这些时间。 (6) 参数K、N、M、S、T 应从命令行输入。 (7) (选做)考虑有些乘客(随机决定)携带的物品体积较大,需占用1~2 人的电 梯空间(随机决定),且上下梯的时间比其他乘客长一倍的情况,再进行相应的仿真(注意, 不是所有的乘客都携带较大体积的物品)。这时,显示乘客及所去往的楼层时要能够识别出 是否携带了较大体积的物品。
### 回答1: 很高兴回答你的问题,Java语言可以用来编写一个单部多线程傻瓜调度(FAFS)电梯系统。要实现这个系统,你需要使用Java线程模拟单部多线程傻瓜调度(FAFS)电梯系统,并使用多线程技术来实现调度算法。此外,你还需要使用Java GUI技术来实现电梯系统的图形界面。 ### 回答2: 单部多线程傻瓜调度(FAFS)电梯系统是一个Java编写的电梯调度系统,它能够同时工作于多个线程,并且是一个简单的调度算法。 该系统的主要功能是通过多线程实现电梯调度和乘客楼层请求的处理。以下是该系统的基本设计思路: 1. 创建电梯(Elevator)和乘客(Passenger),其中电梯包含电梯的状态、当前楼层、电梯移动方向等信息,乘客包含乘客的楼层请求信息。 2. 创建调度器(Scheduler),用于管理所有的电梯和乘客请求。调度器继承自Thread,可以单独运行一个线程,处理所有的电梯和乘客请求。 3. 在调度器中,根据乘客请求,将乘客分配给电梯。调度器使用傻瓜调度算法,即每当有新的请求时,将乘客分配给最近的电梯。 4. 电梯中的run()方法中,通过循环检查当前电梯的状态和楼层。根据电梯的移动方向以及当前楼层,决定是否停靠乘客所请求的楼层,并更新电梯的状态。 5. 在调度器中,监听乘客的请求,并根据乘客请求创建新的乘客对象,并将其分配给电梯。每当有新的乘客请求时,调度器会在电梯中选择最适合的电梯。 6. 调度器和电梯之间通过线程间通信进行交互,当电梯到达某一楼层时,调度器会通知乘客,并更新乘客的状态和楼层信息。 以上是用Java编写单部多线程傻瓜调度(FAFS)电梯系统的基本思路,通过多线程实现电梯调度和乘客请求的处理,以实现高效的电梯调度。 ### 回答3: FAFS电梯系统是一种单部多线程电梯调度系统,使用Java编写。该系统基于先来先服务(First Come First Serve)算法,主要模拟电梯的调度和运行过程。 电梯系统主要由以下几个组成: 1. 电梯(Elevator):表示电梯对象。该包含电梯的当前楼层、运行方向、状态等信息,以及对电梯进行运行、停止、开关门等操作的方法。 2. 乘客(Passenger):表示乘客对象。每个乘客对象包含起始楼层和目标楼层等信息。 3.调度器(Scheduler):负责协调电梯和乘客之间的调度。对于每个请求,调度器根据乘客的楼层请求选择一个最近的空闲电梯,并将乘客请求加入到该电梯的请求队列中。 4. 请求(Request):表示乘客对电梯系统发出的请求。该包含乘客的起始楼层和目标楼层等信息。 在FAFS电梯系统中,每当有乘客发出请求时,调度器将该请求分配给最近空闲的电梯电梯根据当前楼层和运行方向来决定是否响应该请求,并根据乘客请求的楼层顺序来按序处理请求。 电梯通过多线程实现。每个电梯对象都运行在独立的线程中,通过循环监听调度器传递过来的请求队列。电梯通过判断当前楼层与请求队列中的楼层差值来判断响应该请求。一旦响应请求,电梯将执行相应操作,如开关门、运行、停止,并更新当前楼层和运行方向。 整个系统的运行过程是在调度器的主线程中启动的。调度器通过循环监听乘客的请求,并将请求分配给最近的空闲电梯。每个电梯通过独立的线程运行,并通过调度器的请求队列来处理乘客的请求。 FAFS电梯系统利用多线程实现电梯的并行处理,使得乘客的请求可以被快速响应并处理。电梯系统能够提供高效的乘坐体验,减少乘客的等待时间,提高电梯运行效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值