Synchronized来修饰函数和Synchroinzed语句块在使用上的区别

在一个类中,两个不同函数使用

Synchronized来修饰函数f()

在函数g()中使用synchronized(syncObject)语句块

从输出中你能观察到两个方法同时运行,所以它们没有在对方的同步控制上阻塞.


package com.iwindyforest.syn;

/**
* 把方法标记为synchronized : 一旦某个线程处于一个标记为synchronized的方法中,
* 那么这个线程从该方法返回之前,其它要调用类中任何标记为synchronized的方法的线程都会被阻塞. 使用synchronized块 :
* 这也被称为"同步控制块"(synchronized block),在进入此段代码前,
* 必须得到syncObject对象的锁.如果其它线程已经得到这个锁,那么就得等到锁被释放以后,才能进入临界区.
*
* @author chen.yinghua
*/
public class DualSyn
{
private Object syncObject = new Object();

public synchronized void f()
{
System.out.println("Inside f()");
// Doesn't release lock
try
{
Thread.sleep(1000);
}
catch(InterruptedException e)
{
throw new RuntimeException(e);
}

System.out.println("Leaving f()");
}

public void g()
{
synchronized(syncObject)
{
System.out.println("Insied g()");

try
{

Thread.sleep(5000);
}
catch(InterruptedException e)
{
throw new RuntimeException(e);
}

System.out.println("Leaving g()");
}
}
}




package com.iwindyforest.syn;

/**
* DualSync对象的f()方法在this上同步(通过在整个方法上同步),
* g()的同步控制块在syncObject对象上同步.因此,两个同步控制相互独立. 在main()中通过创建调用f()的线程演示了这一点.
* main()线程用来调用g(). 从输出中你能观察到两个方法同时运行,所以它们没有在对方的同步控制上阻塞.
*
* @author chen.yinghua
*/
public class SyncObject
{
public static void main(String[] args)
{
final DualSyn ds = new DualSyn();
new Thread()
{
public void run()
{
ds.f();
}
}.start();

ds.g();
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值