您的位置:首页 > 移动开发 > Objective-C

synchronized(object)的应用场景以及与synchronized修饰方法的区别

2013-12-28 14:36 411 查看
使用synchronized(object) { 代码块.... } 能对代码块进行加锁,不允许其他线程访问,其的作用原理是:在object内有一个变量,当有线程进入时,判断是否为0,如果为0,表示可进入执行该段代码,同时将该变量设置为1,这时其他线程就不能进入;当执行完这段代码时,再将变量设置为0。

想保证代码块在任务情况下都同步,即代码块在程序的中同一时刻只被一个线程调用,即需要使用synchronized( static object)。

代码例子:

public class TestThread {
private static Object lock=new Object(); //必须是静态的。
public  void execute(){
synchronized(lock){
for(int i=0;i<100;i++){
System.out.println(i);
}
}
}
}

object必须是静态变量,否则不同对象调用该方法时也不能同步。

这种技术可以应用在实现JAVA层的悲观锁,例如在DAO类中希望用悲观锁控制某个方法同步(整个app中每次只允许一个线程同时调用)。

至于在JAVA中实现乐观锁,就可以使用volitile变量,在方法开始时将变量先+1,获取值,然后在方法完成时判断该值是否为方法开始时+1的值,如果不是,则表示有其他线程修改过。

与使用synchronized修饰方法的区别

使用synchronized修饰方法,当一个线程进入这个方法后,这个方法的大门就会暂时关闭(不许其他线程进入)直到这个线程走出这个方法后,该方法的大门才会敞开。当然,这个关闭只是对于该类的当前实例有效,多个实例的对象仍然可以同时执行。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: