首页 考试吧论坛 Exam8视线 考试商城 网络课程 模拟考试 考友录 实用文档 求职招聘 论文下载
2011中考 | 2011高考 | 2012考研 | 考研培训 | 在职研 | 自学考试 | 成人高考 | 法律硕士 | MBA考试
MPA考试 | 中科院
四六级 | 职称英语 | 商务英语 | 公共英语 | 托福 | 雅思 | 专四专八 | 口译笔译 | 博思 | GRE GMAT
新概念英语 | 成人英语三级 | 申硕英语 | 攻硕英语 | 职称日语 | 日语学习 | 法语 | 德语 | 韩语
计算机等级考试 | 软件水平考试 | 职称计算机 | 微软认证 | 思科认证 | Oracle认证 | Linux认证
华为认证 | Java认证
公务员 | 报关员 | 银行从业资格 | 证券从业资格 | 期货从业资格 | 司法考试 | 法律顾问 | 导游资格
报检员 | 教师资格 | 社会工作者 | 外销员 | 国际商务师 | 跟单员 | 单证员 | 物流师 | 价格鉴证师
人力资源 | 管理咨询师考试 | 秘书资格 | 心理咨询师考试 | 出版专业资格 | 广告师职业水平
驾驶员 | 网络编辑
卫生资格 | 执业医师 | 执业药师 | 执业护士
会计从业资格考试会计证) | 经济师 | 会计职称 | 注册会计师 | 审计师 | 注册税务师
注册资产评估师 | 高级会计师 | ACCA | 统计师 | 精算师 | 理财规划师 | 国际内审师
一级建造师 | 二级建造师 | 造价工程师 | 造价员 | 咨询工程师 | 监理工程师 | 安全工程师
质量工程师 | 物业管理师 | 招标师 | 结构工程师 | 建筑师 | 房地产估价师 | 土地估价师 | 岩土师
设备监理师 | 房地产经纪人 | 投资项目管理师 | 土地登记代理人 | 环境影响评价师 | 环保工程师
城市规划师 | 公路监理师 | 公路造价师 | 安全评价师 | 电气工程师 | 注册测绘师 | 注册计量师
缤纷校园 | 实用文档 | 英语学习 | 作文大全 | 求职招聘 | 论文下载 | 访谈 | 游戏
您现在的位置: 考试吧(Exam8.com) > 计算机等级考试 > 计算机二级 > JAVA > 复习资料 > 正文

2011年计算机等考二级JAVA学习精华整理(47)

来源:考试吧Exam8.com) 2010-11-23 9:28:46 考试吧:中国教育培训第一门户 模拟考场
考试吧整理了2011年计算机的等考二级JAVA学习精华,帮助考生备考。

  独占方式下,当前执行线程将一直执行下去,直 到执行完毕或由于某种原因主动放弃CPU,或CPU被一个更高优先级的线程抢占分时方式下,当前运行线程获得一个时间片,时间到时,即使没有执行完也要让出CPU,进入可运行状态,等待下一个时间片的调度.系统选中其他可运行状态的线程执行分时方式的系统使每个线程工作若干步,实现多线程同时运行另外请注意下面的线程调度规则(如果有不理解,不急,往下看):

  ①如果两个或是两个以上的线程都修改一个对象,那么把执行修改的方法定义为被同步的(Synchronized),如果对象更新影响到只读方法,那么只度方法也应该定义为同步的

  ②如果一个线程必须等待一个对象状态发生变化,那么它应该在对象内部等待,而不是在外部等待,它可以调用一个被同步的方法,并让这个方法调用wait()

  ③每当一个方法改变某个对象的状态的时候,它应该调用notifyAll()方法,这给等待队列的线程提供机会来看一看执行环境是否已发生改变

  ④记住wait(),notify(),notifyAll()方法属于Object类,而不是Thread类,仔细检查看是否每次执行wait()方法都有相应的notify()或notifyAll()方法,且它们作用与相同的对象 在java中每个类都有一个主线程,要执行一个程序,那么这个类当中一定要有main方法,这个man方法也就是java class中的主线程。你可以自己创建线程,有两种方法,一是继承Thread类,或是实现Runnable接口。一般情况下,最好避免继承,因为java中是单根继承,如果你选用继承,那么你的类就失去了弹性,当然也不能全然否定继承Thread,该方法编写简单,可以直接操作线程,适用于单重继承情况。至于选用那一种,具体情况具体分析。

  eg.继承Thread

  public class MyThread_1 extends Thread

  {

  public void run()

  {

  //some code

  }

  }

  eg.实现Runnable接口

  public class MyThread_2 implements Runnable

  {

  public void run()

  {

  //some code

  }

  }

  当使用继承创建线程,这样启动线程:

  new MyThread_1().start()

  当使用实现接口创建线程,这样启动线程:

  new Thread(new MyThread_2()).start()

  注意,其实是创建一个线程实例,并以实现了Runnable接口的类为参数传入这个实例,当执行这个线程的时候,MyThread_2中run里面的代码将被执行。

  下面是完成的例子:

  public class MyThread implements Runnable

  {

  public void run()

  {

  System.out.println("My Name is "+Thread.currentThread().getName());

  }

  public static void main(String[] args)

  {

  new Thread(new MyThread()).start();

  }

  }

  执行后将打印出:

  My Name is Thread-0

  你也可以创建多个线程,像下面这样

  new Thread(new MyThread()).start();

  new Thread(new MyThread()).start();

  new Thread(new MyThread()).start();

  那么会打印出:

  My Name is Thread-0

  My Name is Thread-1

  My Name is Thread-2

  看了上面的结果,你可能会认为线程的执行顺序是依次执行的,但是那只是一般情况,千万不要用以为是线程的执行机制;影响线程执行顺序的因素有几点:首先看看前面提到的优先级别

  public class MyThread implements Runnable

  {

  public void run()

  {

  System.out.println("My Name is "+Thread.currentThread().getName());

  }

  public static void main(String[] args)

  {

  Thread t1=new Thread(new MyThread());

  Thread t2=new Thread(new MyThread());

  Thread t3=new Thread(new MyThread());

  t2.setPriority(Thread.MAX_PRIORITY);//赋予最高优先级

  t1.start();

  t2.start();

  t3.start();

  }

  }

  再看看结果:

  My Name is Thread-1

  My Name is Thread-0

  My Name is Thread-2

  线程的优先级分为10级,分别用1到10的整数代表,默认情况是5。上面的t2.setPriority(Thread.MAX_PRIORITY)等价与t2.setPriority(10)

  然后是线程程序本身的设计,比如使用sleep,yield,join,wait等方法(详情请看JDKDocument)

  public class MyThread implements Runnable

  {

  public void run()

  {

  try

  {

  int sleepTime=(int)(Math.random()*100);//产生随机数字,

  Thread.currentThread().sleep(sleepTime);//让其休眠一定时间,时间又上面sleepTime决定

  //public static void sleep(long millis)throw InterruptedException (API)

  System.out.println(Thread.currentThread().getName()+" 睡了 "+sleepTime);

  }catch(InterruptedException ie)//由于线程在休眠可能被中断,所以调用sleep方法的时候需要捕捉异常

  {

  ie.printStackTrace();

  }

  }

  public static void main(String[] args)

  {

  Thread t1=new Thread(new MyThread());

  Thread t2=new Thread(new MyThread());

  Thread t3=new Thread(new MyThread());

  t1.start();

  t2.start();

  t3.start();

  }

  }

  执行后观察其输出:

  Thread-0 睡了 11

  Thread-2 睡了 48

  Thread-1 睡了 69

  上面的执行结果是随机的,再执行很可能出现不同的结果。由于上面我在run中添加了休眠语句,当线程休眠的时候就会让出cpu,cpu将会选择执行处于runnable状态中的其他线程,当然也可能出现这种情况,休眠的Thread立即进入了runnable状态,cpu再次执行它。

上一页  1 2 3 4 5 下一页
  相关推荐:计算机等级考试二级Java经典算法大全汇总

       2010年9月计算机等级考试成绩查询时间汇总

        2011计算机等级考试二级JAVA学习精华汇总

文章搜索
版权声明:如果计算机等级考试网所转载内容不慎侵犯了您的权益,请与我们联系800@exam8.com,我们将会及时处理。如转载本计算机等级考试网内容,请注明出处。