Chinaunix首页 | 论坛 | 博客
  • 博客访问: 376040
  • 博文数量: 1051
  • 博客积分: 53280
  • 博客等级: 大将
  • 技术积分: 6670
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-09 13:21
文章分类

全部博文(1051)

文章存档

2011年(1)

2008年(1050)

我的朋友

分类:

2008-09-09 16:49:17


  四种方式 sychronized关键字
  sychronized method(){}
  sychronized (objectReference) {/*block*/}
  static synchronized method(){}
  sychronized(classname.class)
  其中1和2是代表锁当前对象,即一个对象就一个锁,3和4代表锁这个类,即这个类的锁
  要注意的是sychronized method()不是锁这个函数,而是锁对象,即:如果这个类中有两个方法都是sychronized,那么只要有两个线程共享一个该类的reference,每个调用这两个方法之一,不管是否同一个方法,都会用这个对象锁进行同步。锁类的3和4类推,即该类的不同reference调用了sychronized区段的咚咚就会受类锁的控制
  
  还有,如果两个函数调用的先后顺序不能被打断,那么可以有个专门的锁对象来完成这个任务:
  class MyLock
  {
     synchronized getLock()
     {
       //####还没写完
     }
  }
  
  五个等级  参见effective java Item 52 : Document thread safety
  
  immutable  不可变对象
  thread-safe 线程的,可以放心使用,如java.util.Timer
  conditionally thread-safe 条件线程的,如Vector和Hashtable,一般是安全的,除非存在几个方法调用之间的顺序不能被打断,这时可以用额外的锁来完成
  thread-compatible 可以使用synchronized (objectReference)来协助完成对线程的调用
  thread-hostile 不安全的
  
  wait & notifyAll
  
  在循环中使用wait 使用notifyAll而不是notify
  
  pipe
  
  java中也有pipe的,四个类:PipedInputStream, PipedInputReader, PipedOutputStream, PipedOutputWriter 下面是一段生产者消费者的代码(摘自core javaII):
  
    /* set up pipes */
    PipedOutputStream pout1 = new PipedOutputStream();
    PipedInputStream pin1 = new PipedInputStream(pout1);
    PipedOutputStream pout2 = new PipedOutputStream();
    PipedInputStream pin2 = new PipedInputStream(pout2);
    /* construct threads */
    Producer prod = new Producer(pout1);
    Filter filt = new Filter(pin1, pout2);
    Consumer cons = new Consumer(pin2);
    /* start threads */
    prod.start(); filt.start(); cons.start();
  
  
【责编:admin】

--------------------next---------------------

阅读(204) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~