日期:2014-05-20  浏览次数:20619 次

今天看了线程同步synchronized应用于方法,果断不懂了,有感兴趣的朋友希望能解答一下


class runner1 implements Runnable
{
int b = 100;
public synchronized void m1() throws Exception
{
b = 1000;
Thread.sleep(5000);
System.out.println("b = " + b);
}
public synchronized void m2() throws Exception  
{
Thread.sleep(2500);
b = 2000;
}
@Override
public void run() {
try
{
m1();
}catch(Exception e){e.printStackTrace();}
}
}

public class TT {
public static void main(String[] args)  throws Exception
{
runner1 tt = new runner1();
Thread thread = new Thread(tt);
thread.start();

tt.m2();
}
}


如果m2方法去掉synchronized,结果不同
我想问一下,synchronized应用于方法来说,是把this对象锁起来,但对去掉synchronized的m2方法,它为什么可以修改对象的内容?

------解决方案--------------------
你的程序启动了两个线程,一个是main线程,一个是start启动的tt线程,当你thread.start();jvm虚拟机就启动了一个线程,和主线程main有一样的待遇,他们可以并行的。但是,你的对runner类的两个方法都是用了synchronized的关键字,说明只有一个线程可以共享这个对象。可是,你启动的两个线程都要竞争这个资源,怎么办呢?很简单,谁抢到资源谁就执行,前面也说了,启动的两个线程有一样的待遇,谁得到cpu的宠幸呢?就可以谁抢到先,-------你也许会认为是thread.start()这个线程,但是你要记住,当启动线程了,不代表他马上得到资源去执行它的run方法,start()这能说这个线程启动了,要想得到cpu的宠幸,这不是你start就可以的,这个要交给操作系统去调度的。所以说,thread这个子线程和main这个主线程,都有可能得到资源,先执行,因为你看到的结果是1000,那么可以确定,main主线程线先得到了runner的资源,然后休眠2500,然后执行该执行的,就完成了,就释放锁,给thread得到资源。thread后执行,所以b有被设置为1000了,希望对你有帮助