模拟售票窗口

多线程(三)—模拟窗口售票

请你编写一个程序用于模拟多窗口售票。要求:1、窗口数目由键盘输入。2、总的票数也由键盘输入。3、每一张票都有一个编号,从1号开始。4、每个窗口售票都是先售出号码最小的票。5、输出每个窗口售票的情况:窗口号+所售票号。6、最后输出每个窗口售出的票的总数。7、当票售完后,窗口输出“票已售完”,并结束线程。可能的运行结果如下:在这里插入图片描述
在这里插入图片描述
具体代码如下:

package main;
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    int n = sc.nextInt();
    int m = sc.nextInt();
        MyThread netAnt = new MyThread(n,m);
        Thread my[]= new Thread[m+1];
        for(int i = 1;i <= m;i++){
           my[i] = new Thread(netAnt,"售票窗口"+i);
            my[i].start();
        }
    }
}
class MyThread implements Runnable {
private int tickets;
private int num=1;
private int end=0;
private int m;
private int a[];
public int getEnd() {
return end;
}
public void setEnd(int end) {
this.end = end;
}
public MyThread(int tickets,int m) {
     this.tickets=tickets;
     this.m=m;
     a = new int[m+1];
}
@Override
public void run() {
synchronized (this) {
int i=1,d=0;
if (tickets > 0) {
for (i = 1;i<=tickets;i++) {
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}

System.out.println(Thread.currentThread().getName()+"正在售票,当前余票是:"+tickets--+".售出票号是:"+num++);
}
a[Thread.currentThread().getName().charAt(4)-'0']=i-1;
}
if(tickets==0) {
for(i=1;i<=m;i++) {
System.out.println("票已售完.售票窗口"+i+"共售票"+a[i]+"张");
}
tickets=-1;
}
}
}

public synchronized void sell() {
int i=1;
for (i = 1;i<=tickets;i++) {
System.out.println(Thread.currentThread().getName()+"正在售票,当前余票是:"+tickets--+".售出票号是:"+num++);
}

if(tickets>0) {
this.end=this.end+i-1;
}System.out.println("票已售完."+Thread.currentThread().getName()+"共售票"+this.end+"张");
}
}
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
通过优先级调度算法的模拟,加深进程概念和进程调度过程的理解。设计原理及方案:1)在Linux下用C语言编程模拟优先级程调度算法。为了清楚地观察每个进程的调度过程,程序将每个时间片内的进程情况显示出来。2)进程控制块是进程存在的唯一标志,因此,在模拟算法中每一个进程用一个进程控制块PCB来代表,PCB用一结构体表示。3)进程在运行过程中其状态将在就绪、执行、完成几种状态之间转换,同时进程可能处于不同的队列中,如就绪队列。在优先级调度算法中,选择单向队列,入队既是将进程控制块插入队尾,出队既是按优先级重新排列的队,删除队头元素。4)为了便于处理,程序中的某进程运行时间以时间片为单位计算。各进程的优先级认为输入,运行所需时间随机产生。5)优先权调度算法采用动态优先权,进程每运行一个时间片,优先数减1;进程在就绪队列等待一个时间单位,优先数加1。6)对于遇到优先权一致的情况,采用FCFS策略解决。7)由于是模拟进程调度,所以,对被选中的进程并不实际启动运行,而是修改进程控制块的相关信息来模拟进程的一次运行。 分别用两种调度算法对伍个进程进行调度。每个进程可有三种状态;执行状态(R)、就绪状态(W,包括等待状态)和完成状态(F,并假定初始状态为就绪状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大大大大龙虾

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值