龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 软件开发 > JAVA开发 >

Java 线程综合述

时间:2009-12-23 15:42来源:未知 作者:admin 点击:
分享到:
编写具有多线程能力的程序经常会用到的方法有: run(), start(), wait(), notify(), notifyAll(), sleep(), yield(), join() 还有一个重要的要害字:synchronized 本文将对以上内容进行讲解。 一:run() 和

  编写具有多线程能力的程序经常会用到的方法有:
  
     run(), start(), wait(), notify(), notifyAll(), sleep(), yield(), join()
  
     还有一个重要的要害字:synchronized
  
     本文将对以上内容进行讲解。
  
     一:run() 和start()
  
     示例1:
  
   public class ThreadTest extends Thread {
   public void run() {
   for (int i = 0; i < 10; i++) {
   System.out.print(" " + i);
   }
   }
  
   public static void main(String[] args) {
   new ThreadTest().start();
   new ThreadTest().start();
   }
  }
  
  这是个简单的多线程程序。run() 和start() 是大家都很熟悉的两个方法。把希望并行处理的代码都放在run() 中;stat() 用于自动调用run(),
   这是Java的内在机制规定的。并且run() 的访问控制符必须是public,返回值必须是void(这种说法不准确,run() 没有返回值),run()
   不带参数。
  
     这些规定想必大家都早已知道了,但你是否清楚为什么run方法必须声明成这样的形式?这涉及到JAVA的方法覆盖和重载的规定。这些内容很重要,
   请读者参考相关资料。
  
     二:要害字synchronized
  
     有了synchronized要害字,多线程程序的运行结果将变得可以控制。synchronized要害字用于保护共享数据。请大家注重 "共享数据",
   你一定要分清哪些数据是共享数据,JAVA是面向对象的程序设计语言,所以初学者在编写多线程程序时,轻易分不清哪些数据是共享数据。请看下面的例子:
  
     示例2:
  
   public class ThreadTest implements Runnable {
  
   public synchronized void run() {
   for (int i = 0; i < 10; i++) {
   System.out.print(" " + i);
   }
   }
  
   public static void main(String[] args) {
   Runnable r1 = new ThreadTest();
   Runnable r2 = new ThreadTest();
   Thread t1 = new Thread(r1);
   Thread t2 = new Thread(r2);
   t1.start();
   t2.start();
   }
  }
  
  在这个程序中,run() 被加上了synchronized要害字。在main方法中创建了两个线程。你可能会认为此程序的运行结果一定为:0123456789
   0123456789。但你错了!这个程序中synchronized要害字保护的不是共享数据(
   其实在这个程序中synchronized要害字没有起到任何作用,此程序的运行结果是不可预先确定的)。这个程序中的t1, t2是两个对象(r1,
   r2)的线程。JAVA是面向对象的程序设计语言,不同的对象的数据是不同的,r1,
   r2有各自的run() 方法,而synchronized使同一个对象的多个线程,
   在某个时刻只有其中的一个线程可以访问这个对象的synchronized数据。每个对象都有一个 "锁标志",
   当这个对象的一个线程访问这个对象的某个synchronized数据时,这个对象的所有被synchronized修饰的数据将被上锁(因为 "锁标志"
   被当前线程拿走了),只有当前线程访问完它要访问的synchronized数据时,当前线程才会释放 "锁标志",
   这样同一个对象的其它线程才有机会访问synchronized数据。
  
     示例3:
  
   public class ThreadTest implements Runnable {
   public synchronized void run() {
   for (int i = 0; i < 10; i++) {
   System.out.print(" " + i);
   }
   }
  
   public static void main(String[] args) {
   Runnable r = new ThreadTest();
   Thread t1 = new Thread(r);
   Thread t2 = new Thread(r);
   t1.start();
  
   t2.start();
   }
  }
  
  假如你运行1000次这个程序,它的输出结果也一定每次都是:01234567890123456789。因为这里的synchronized保护的是共享数据。
  
精彩图集

赞助商链接