Chinaunix首页 | 论坛 | 博客
  • 博客访问: 177729
  • 博文数量: 6
  • 博客积分: 1425
  • 博客等级: 上尉
  • 技术积分: 575
  • 用 户 组: 普通用户
  • 注册时间: 2005-09-21 15:56
文章分类

全部博文(6)

文章存档

2008年(6)

我的朋友

分类: Java

2008-09-29 11:22:32

    相对于C++需要自己编写信号量处理,java的synchronized简化了这方面的处理。

  • java里的每一个对象都含有一个单一的锁(也成为监视器),这个锁本身就是对象的部分(你自己不用编写任何代码)当你在对象上调用任何synchronized的方法和块时,此对象就被加锁,这时对象上的其他synchronized方法和块只有等待前一个synchronized调用完毕释放锁以后才能被调用。所以,对于某个对象,其所有的synchronized方法和块共享同一个锁

  • 一个线程可以多次获得对象的锁。如果一个方法在同一个对象上调用了第二个方法,后者有调用了同一对象的另一个方法,JVM负责将对象的锁加1,如果退出则减1。只有首先获得锁的线程才能获得多个锁。

  • 针对每一个类,也有一个锁,synchronized static...作用于类范围。
  
   概而言之,java的synchronized以object为单位控制race condition,并且其用内部锁机制简化开发人员的开发。
   提醒一下,在设计上,对共享资源的读和写方法都需要是synchronized。



阅读(2449) | 评论(0) | 转发(0) |
0

上一篇:Anonymous Inner Classes

下一篇:关于volatile

给主人留下些什么吧!~~