十字路口交通信号灯问题之代码实现

2024-03-15 06:08

本文主要是介绍十字路口交通信号灯问题之代码实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在上一篇博客<<十字路口交通信号灯问题之需求解析>>中介绍了程序的需求,这篇博客将给大家介绍代码如何实现,实现中没有实现GUI,只是对十字路口交通信号灯的逻辑进行了简单的实现.

 

Road.

/*** 每个Road对象代表一条路线,总共有12条路线,即系统中总共要产生12个Road实例对象。* 每条路线上随机增加新的车辆,增加到一个集合中保存。* 每条路线每隔一秒都会检查控制本路线的灯是否为绿,是则将本路线保存车的集合中的第一辆车移除,即表示车穿过了路口。* @author 张孝祥 www.it315.org**/
public class Road {private List<String> vechicles = new ArrayList<String>();private String name = null;public Road(String name) {this.name = name;//模拟车辆不断随机上路的过程	ExecutorService pool = Executors.newSingleThreadExecutor();pool.execute(new Runnable() {@Overridepublic void run() {for (int i = 1; i < 100; i++) {try {Thread.sleep((new Random().nextInt(10)+1)*1000);} catch (InterruptedException e) {e.printStackTrace();}vechicles.add(Road.this.name + " _" + i);}}});//每隔一秒检查对应的灯是否为绿,是则放行一辆车	ScheduledExecutorService timer = Executors.newScheduledThreadPool(1);timer.scheduleAtFixedRate(new Runnable(){public void run(){if(vechicles.size() >0){boolean lighted = true;if(lighted = true){System.out.println(vechicles.remove(0) + "is traversing !");vechicles.remove(0);}}}},1,1,TimeUnit.SECONDS);}
}


Lamp类:

<span style="font-family:Times New Roman;font-size:18px;">/*** 每个Lamp元素代表一个方向上的灯,总共有12个方向,所有总共有12个Lamp元素。* 有如下一些方向上的灯,每两个形成一组,一组灯同时变绿或变红,所以,* 程序代码只需要控制每组灯中的一个灯即可:* s2n,n2s    * s2w,n2e* e2w,w2e* e2s,w2n* s2e,n2w* e2n,w2s* 上面最后两行的灯是虚拟的,由于从南向东和从西向北、以及它们的对应方向不受红绿灯的控制,* 所以,可以假想它们总是绿灯。* @author 张孝祥 www.it315.org**/
/**/
public enum Lamp {/*每个枚举元素各表示一个方向的控制灯*/	S2N("N2S","S2W",false),S2W("N2E","E2W",false),E2W("W2E","E2S",false),E2S("W2N","S2N",false),/*下面元素表示与上面的元素的相反方向的灯,它们的“相反方向灯”和“下一个灯”应忽略不计!*/N2S(null,null,false),N2E(null,null,false),W2E(null,null,false),W2N(null,null,false),/*由南向东和由西向北等右拐弯的灯不受红绿灯的控制,所以,可以假想它们总是绿灯*/S2E(null,null,true),E2N(null,null,true),N2W(null,null,true),W2S(null,null,true);private Lamp(String opposite,String next,boolean lighted){this.opposite = opposite;this.next = next;this.lighted = lighted;}/*当前灯是否为绿*/	private boolean lighted;/*与当前灯同时为绿的对应方向*/	private String opposite;/*当前灯变红时下一个变绿的灯*/	private String next;public boolean isLighted(){return lighted;}/*** 某个灯变绿时,它对应方向的灯也要变绿*/	public void light(){this.lighted = true;if(opposite != null){Lamp.valueOf(opposite).light();}System.out.println(name() + " lamp is green,下面总共应该有6个方向能看到汽车穿过!");}/*** 某个灯变红时,对应方向的灯也要变红,并且下一个方向的灯要变绿* @return 下一个要变绿的灯*/	public Lamp blackOut(){this.lighted = false;if(opposite != null){Lamp.valueOf(opposite).blackOut();}		Lamp nextLamp= null;if(next != null){nextLamp = Lamp.valueOf(next);System.out.println("绿灯从" + name() + "-------->切换为" + next);			nextLamp.light();}return nextLamp;}
}</span>


LampController类:

<span style="font-family:Times New Roman;font-size:18px;">public class LampController {private Lamp currentLamp;public LampController(){//刚开始让由南向北的灯变绿;		currentLamp = Lamp.S2N;currentLamp.light();/*每隔10秒将当前绿灯变为红灯,并让下一个方向的灯变绿*/		ScheduledExecutorService timer =  Executors.newScheduledThreadPool(1);timer.scheduleAtFixedRate(new Runnable(){public  void run(){System.out.println("来啊");currentLamp = currentLamp.blackOut();}},10,10,TimeUnit.SECONDS);}
}</span>

main函数:

<span style="font-family:Times New Roman;font-size:18px;">public static void main(String[] args) {/*产生12个方向的路线*/		String [] directions = new String[]{"S2N","S2W","E2W","E2S","N2S","N2E","W2E","W2N","S2E","E2N","N2W","W2S"		};for(int i=0;i<directions.length;i++){new Road(directions[i]);}/*产生整个交通灯系统*/		new LampController();}
</span>


运行结果:


这个小程序挺有意思的,大家有时间可以写写.


这篇关于十字路口交通信号灯问题之代码实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/811034

相关文章

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Spring Gateway动态路由实现方案

《SpringGateway动态路由实现方案》本文主要介绍了SpringGateway动态路由实现方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前沿何为路由RouteDefinitionRouteLocator工作流程动态路由实现尾巴前沿S

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.