本帖最后由 huoyu123 于 2011-3-1 17:30 编辑 Java多线程的同步依靠的是对象锁机制,synchronized关键字的背后就是利用了封锁来实现对共享资源的互斥访问。 下面以一个简单的实例来进行对比分析。实例要完成的工作非常简单,就是创建10个线程,每个线程都打印从0到99这100个数字,希望线程之间不会出现交叉乱序打印,而是顺序地打印。 先来看第一段代码,这里我们在run()的调用方法中加入了synchronized关键字,希望能对run方法进行互斥访问,但结果并不如我们希望那样,这是因为这里synchronized锁住的是this对象,即当前运行线程对象本身。Java多线程代码中创建了10个线程,而每个线程都持有this对象的对象锁,这不能实现线程的同步。 如何达到我们想要的要求呢? 答案就是在run()调用的方法taskHandler中加上static 声明, synchronized关键字就会锁定静态类的实例对象, 线程是互斥访问的, 这样就可以达到线程的同步要求了。代码如下: package com.Glaivelee.MultiThreading.thread001; public class myThread001 { public static void main(String[] args) { for(int i = 0 ; i < 10 ; i++){ new Thread(new MyThread(i))。start(); }}} class MyThread implements java.lang.Runnable{ private int threadID; public MyThread(int id){ this.threadID = id; } public void run(){ taskHandler(this.threadID); } //线程锁 private synchronized void taskHandler(int threadID){ for(int i = 0 ; i < 100 ; i++){ System.out.println("thread ID:"+threadID + " : " + i); }}} 作者:王姿 |
-
2011-05-25
-
2011-05-25
-
2011-05-25
你会成功的!