本文主要是介绍十字路口交通信号灯问题之代码实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在上一篇博客<<十字路口交通信号灯问题之需求解析>>中介绍了程序的需求,这篇博客将给大家介绍代码如何实现,实现中没有实现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>
运行结果:
这个小程序挺有意思的,大家有时间可以写写.
这篇关于十字路口交通信号灯问题之代码实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!