`
想学跑的猪
  • 浏览: 15387 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

黑马程序员_面试题_交通灯管理系统

阅读更多

  

            ------ android培训java培训、java基础学习技术总结、期待与您交流! ----------

 

交通灯管理系统的项目需求
     *
     *模拟实现十字路口的交通灯管理系统逻辑,具体需求如下:
     *异步随机生成按照各个路线行驶的车辆。
     *例如:
     *由南向而来去往北向的车辆---直行车辆
     *由西向而来去往南向的车辆---右转车辆
     *由东向而来去往南向的车辆---左转车辆
     *。。
     *信号灯忽略黄灯,只考虑红灯和绿灯。
     *应考虑左转车辆控制信号灯,右转车辆不受信号灯控制。
     *具体信号灯控制逻辑与实现生活中普通交通灯逻辑控制相同,不考虑特殊情况
     *下的控制逻辑。
     *注南北向车辆与东西向车辆交替放行,同方位等待车辆而后放行左转车辆。
     *每辆车通过路口时间为一秒(提示:可通过线程Sleep的方式模拟)。
     *随机声称车辆时间间隔以红绿灯交换时间间隔自定,可以设置。
     *不要求实现GUI,只考虑系统逻辑实现,可通过Log方式展现程序运行结果。
     *总共有12条路线,为了统一编程模型,可以假设每条路线都有一个红绿灯对其控制,
     *右转弯的4条路线的控制灯可以假设称为常绿状态,另外,其他的8条路线是两两成对
     *的,可以归为4组,所以,程序只需考虑图中标注了数字号的4条路线的控制灯的切换
     *顺序,这4条路线相反方向的路线的控制灯跟随这四条路线切换,不必额外考虑。                                          
     *
     *
     *
     *
     *面向对象的分析与设计
     *每条路线上都会出现多车辆,路线上要随机增加新的车,在灯绿间还要每秒钟减少
     *一辆车。
     *设计一个Road类来表示路线,每个Road对象代表一条路线,总共有12条路线,即系统
     *总共要产生12个Road对象
     *每条路线上随机增加新的车辆,增加到一个集合中保存。
     *每条路线每隔一秒都会检查控制本路线是否为绿,一个灯由绿变红时,应该将
     *下一个方向的灯变绿 。
     *设计一个Lamp类来表示一个交通灯,每个交通灯都维护一个状态:亮(绿)或不亮(红),
     *每个交通灯要变亮和变黑的方法,并且能返回自己的亮黑状态。
     *总共有12条路线,所以,系统中总共要产生12个交通灯。右拐弯的路线本来不收灯的控制,
     *但是为了让程序采用统一的处理方式,固假设出有四个右拐弯的灯,只是这些灯为常量状态
     *,即永远不变黑。
     *除了右拐弯方向的其他8条路线的灯,它们是两两成对的,可以归为四组,所以,在编程处理是,只要从四组中各曲
     *出一个灯,对这4个灯依次轮询变亮,与这4个灯方向相反灯,在一个Lamp对象的变量和变黑方法中,
     *将对应方向的灯也变亮和变黑。每个灯变黑时,都伴随着洗衣歌灯的变亮,Lamp类中还用一个变量记住自己的下
     *下一个灯。灯
     *
     *面向对象设计把握一个中要经验:睡拥有数据,谁就对外提供操作这些数据的方法。在牢牢掌握几个典型的案例就可以了:
     *人在黑板上画圆,列车司机紧急刹车,售票员统计收获小票的金额,你把门关上了等。
     *学员的两个面向对象的面试题,用面向对象的设计方法设计如下情景。
     *两块石头磨成一把刀,石刀可以砍树,砍成木材,木材做成椅子,
     *球从一根绳子的一端移动到了另一端。
     *
     *
     *Road类的编写
     *每个Road对象都有一个name成员变量来代表方向,有一个vehicles成员变量来代表方向上的车辆集合。
     *在Road对象的构造方法中启动一个线程每个一个随机的时间向vehicles集合中增加一辆车(用一个“路线名_id”形式的字符
     *串进行表示)。
     *在Road对象的构造方法中启动一个定时器,每个一秒检查该方向上的灯是否为绿,是则打印车辆集合中的第一个车辆

代码如下:

            Road类

public class Road {
       List<String> vechicles=new ArrayList<String>();
     
       private String name=null;
       public Road(final String name){
    	   this.name=name;
    	   System.out.println(name); 
    	  ExecutorService pool=Executors.newSingleThreadExecutor();
    	  pool.execute(new Runnable(){

			@Override
			public void run() {
				 for(int i=1;i<1000;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=Lamp.valueOf(name).isLighted(); 
    				  /*System.out.println(Lamp.valueOf(name)); 
    				  System.out.println(lighted);  */ 
    				  if(lighted){ 
    					 System.out.println(vechicles.remove(0)+"     is travllering"); 
    				  }
    			  }
    		  }
    	  },
    			  1,
    			  1,
    			  TimeUnit.SECONDS); 
    	  
       }
}

         Lamp枚举

public enum Lamp {
      S2N("N2S",false,"S2W"),S2W("N2E",false,"E2W"),
      E2W("W2E",false,"E2S"),E2S("W2N",false,"S2N"), 
      N2S(null,false,null),N2E(null,false,null),W2E(null,false,null),
      W2N(null,false,null),
      S2E(null,true,null),E2N(null,true,null),N2W(null,true,null),
      W2S(null,true,null);
      
       
      private boolean lighted;
      private String oppsite;
      private String next;
      private Lamp(String oppsite,boolean ligthed,String next){
    	  this.oppsite=oppsite;
    	  System.out.println(lighted);
    	  this.lighted=true; 
    	  this.next=next;
    	  
      }
      
      public void light(){
    	  this.lighted=true; 
    	  if(oppsite!=null){
    		  Lamp lampOppsite=Lamp.valueOf(oppsite);
    		  lampOppsite.light();
    	  }
    	  System.out.println((name()+" lamp is green,下面总共应该有6个方向能看到汽车穿过!"));
    	  
      }
      public boolean isLighted(){
		  return this.lighted;
	  }
      public Lamp blackOut(){
		  this.lighted=false;
		  if(oppsite!=null){
			  Lamp lampOppsite=Lamp.valueOf(oppsite);
			  lampOppsite.blackOut();
		  }
		  Lamp nextLamp=null;
		  if(next!=null){
			  nextLamp=Lamp.valueOf(next);
			  nextLamp.light();
			  System.out.println("绿灯从"+name()+"--------->切换为"+next);
		  }
		  return nextLamp;
	  }
}

      LampController类

public class LampController {
  private static LampController instance=new LampController();
 
  public static LampController getInstance(){
	  return instance;
  }
  private Lamp currentLamp=null;
  private LampController(){
	  currentLamp=Lamp.S2N;  
	  currentLamp.light(); 
  } 
  public void start(){
	
	  Executors.newScheduledThreadPool(1).scheduleAtFixedRate(
			  new Runnable(){
				  public void run(){
					  currentLamp=currentLamp.blackOut();
				  }
				  
			  },
			  10,10,TimeUnit.SECONDS);
	  
	  
  }
  
}

      TrafficTest类

public class TrafficTest {

	public static void main(String[] args) {
		// TODO Auto-generated method stub		
		   new Road("S2N");
		   new Road("S2W");
		   new Road("E2W");
		   new Road("E2S");
		   new Road("N2S");
		   new Road("N2E");
		   new Road("W2E");
		   new Road("W2N");
           new Road("S2E");
           new Road("E2N"); 
           new Road("N2W");
           new Road("W2S"); 
         LampController con=LampController.getInstance();
         con.start();
	}

}

 

 

 

            ------ android培训java培训、java基础学习技术总结、期待与您交流! ----------

分享到:
评论

相关推荐

    java_examine.rar_java 试题_程序员 面试_程序员面试_面试_面试题

    视频文件"java_examine.wmv"很可能是由经验丰富的讲师或行业专家提供的面试题解析,涵盖了Java基础、面向对象设计、多线程、集合框架、异常处理、JVM内存管理、IO流、网络编程、数据库连接、设计模式等多个方面。...

    Aspnet中级程序员_面试题

    【Aspnet中级程序员面试题】是针对有一定经验的Asp.net开发者设计的考核内容,主要涵盖C#、ASP.NET、SQL以及DBA等相关技术领域。这些知识点在实际开发和项目管理中至关重要,下面将对这些核心领域进行深入探讨。 **...

    《JAVA面试题》--JAVA 黑马程序员 面试宝典全学科.zip

    十余年JAVA从业经验,精通JAVA技术体系,有志于做JAVA技能提升的朋友可与我联系,交个朋友 十余年JAVA从业经验,精通JAVA技术体系,有志于做JAVA技能提升的朋友可与我联系,交个朋友 十余年JAVA从业经验,精通JAVA...

    01-7K月薪面试题破解之一_交通灯管理系统视频教程

    交通灯管理系统视频教程01-7K月薪面试题破解之一_交通灯管理系统视频教程01-7K月薪面试题破解之一_交通灯管理系统视频教程01-7K月薪面试题破解之一_交通灯管理系统视频教程01-7K月薪面试题破解之一_交通灯管理系统...

    黑马程序员_毕向东_Java基础源码.rar

    这个名为“黑马程序员_毕向东_Java基础源码.rar”的压缩包文件,包含了丰富的Java基础源代码实例,对于初学者来说,是深入了解Java编程的良好资源。 一、Java基本语法 Java语言以其严格的类型检查和面向对象特性...

    java程序员早期面试题汇总.zip

    java程序员早期面试题汇总 BAT经典面试题汇总.pdf Java常考面试题.pdf java面试题(题库全).doc java面试题-外企软件工程师面试题大全.rar 程序员面试题精选100题.pdf ... --------------------------------...

    黑马程序员java面试宝典 完整版PDF.rar

    《黑马程序员Java面试宝典》是一本...通过《黑马程序员Java面试宝典》的学习,你可以系统地复习和掌握这些知识点,提高自己的面试竞争力。书中的问题和解答将帮助你更好地理解Java编程的本质,提升在面试中的自信心。

    【黑马面试宝典】虐面试官神器之必备黑马程序员Android面试宝典.zip

    Android面试宝典包含两个宝典: 1【黑马项目宝典】虐面试官神器之必备黑马程序员项目宝典V1.1 内容包括:(1)电子商城(2)ListView系列(3)图像处理(4)动画效果(5)控件大全(6)新闻资讯(7)生活相关(8)...

    JAVAAndroid面试题讲解视频

    资源名称:JAVA Android面试题讲解视频资源目录:【】2012黑马程序员01_面试题【】2012黑马程序员02_面试题【】2012黑马程序员03_面试题【】2012黑马程序员04_面试题【】225ce844c6c817e9614d8f17ea70a640【】...

    bishiti.rar_C 面试题_c 笔试_笔试_面试_面试题

    "bishiti.rar_C 面试题_c 笔试_笔试_面试_面试题"这个压缩包包含了针对C语言的笔试和面试题目,旨在帮助求职者更好地准备技术面试,提高通过率。下面将详细讨论C语言的一些关键知识点。 1. **数据类型**:C语言提供...

    .net程序员面试题

    收集了很多师兄师姐出去就业后,收集回来的企业面试.net程序员的面试题啊!不容易啊!1-8份面试题,好好看啊!都是技术题,祝面试上自己喜欢的职业

    Java程序员就业面试题大全

    Java程序员就业面试题大全Java程序员就业面试题大全Java程序员就业面试题大全Java程序员就业面试题大全Java程序员就业面试题大全Java程序员就业面试题大全

    IT程序员高频面试题梳理码农高频面试题梳理

    IT程序员高频面试题梳理码农高频面试题梳理 P33 IT程序员高频面试题梳理码农 高频面试题梳理 IT程序员高频面试题梳理码农高频面试题梳理 IT程序员高频面试题 梳理码农高频面试题梳理 IT程序员高频面试题梳理码农高频...

    【黑马面试宝典】虐面试官神器之必备黑马程序员面试宝典V2.51

    "【黑马面试宝典】虐面试官神器之必备黑马程序员面试宝典V2.51"是为准备面试的程序员提供的一份宝贵的资源,它涵盖了JavaSE基础、面向对象、多态以及异常处理等多个核心知识点。本文将详细解析这些内容,帮助你更好...

    C程序员语言面试100题.rar_C语言100题_C语言笔试面试_C语言面试题_程序员笔试题_阿里

    《C程序员语言面试100题》是针对C语言编程技术的一份综合性的面试题集,涵盖了华为、中兴、阿里、腾讯等知名企业的常见笔试和面试问题。这份资料旨在帮助程序员深入理解和熟练掌握C语言的基础知识,以及在实际开发中...

    c_c++mianshiti.rar_C 面试题_C++ 面试_c程序_面试_面试题

    本文对C/C++程序员应聘的常见面试题进行了深入剖析

    Java 面试题库,2018-2019年黑马最新版Java程序员面试宝典+题库pdf.zip

    我们培训班刚发的面试题,2018年黑马最新程序员面试宝典+题库,内容包含大量java程序员初级知识点,以及框架的应用,js的基础。需要的赶紧下载准备面试吧. 2019年黑马最新版面试宝典题库 黑马 最新版面试 宝典题库

    黑马程序员java基础试题、笔记

    黑马程序员面试技巧则提供了面试策略和技巧,如如何清晰地表达思路,怎样在短时间内回顾和整理知识,以及如何应对压力和临场表现。这些非技术性的技巧同样对求职过程有着重要影响。 想进黑马必须掌握的重点知识这...

    java面试题 程序员面试 逻辑题 笔试题

    java面试题 程序员面试 逻辑题 笔试题

Global site tag (gtag.js) - Google Analytics