对于线程并发的数据同步,JAVA提供了synchronized供选择。加了synchronized方法或者代码块儿,如果一个线程进入synchronized,那么这个线程获得对应对象的锁,其他线程只能等待获取这个对象的锁。对于线程中锁,最重要的两点是确定锁的对象是谁,谁持有了锁。我相信上面的理解应该没有错吧,那么对于下面的代码有一些疑问,伪代码:publicclassTestThreadimplementsRunnable{publicstaticObjecto1=newLong(-1);publicstaticObjecto2=newLong(-2);@Overridepublicvoidrun(){synchronized(o1){System.out.println("Iamo1:"+Thread.currentThread().getName());}synchronized(o2){System.out.println("Iamo2:"+Thread.currentThread().getName());}}}staticExecutorServiceexecutorService=Executors.newFixedThreadPool(3);publicstaticvoidmain(String[]args){executorService.submit(newTestThread());executorService.submit(newTestThread());executorService.submit(newTestThread());executorService.shutdown();}现在创建了三个线程,每个线程执行到synchronized后,其他线程都要等待。我的问题是:1.创建了三个线程,每个线程中o1、o2都是不同的对象。根据我的理解,线程获取到的都是不同对象的锁,因此线程执行到synchronized代码块儿,其他程序执行到同样地方都拿到的是不同对象的锁,理应不会发生等待的。是我的那里理解的有问题吗?
慕少森
慕工程0101907
相关分类