在下面的示例中,有人可以告诉我方法stampaVector()和stampaVector2()之间的区别吗?
public class ThreadConcurrence implements Runnable{
ArrayList<Integer> list=null;
public ThreadConcurrence(ArrayList<Integer> list){
this.list = list;
}
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<Integer>();
for(int i=0; i<5; i++){
list.add(i);
}
//Threads shares same list object
ThreadConcurrence tc1 = new ThreadConcurrence(list);
ThreadConcurrence tc2 = new ThreadConcurrence(list);
Thread t1 = new Thread(tc1);
Thread t2 = new Thread(tc2);
t1.start();
t2.start();
}
@Override
public void run() {
stampaVector();
//stampaVector2();
}
public void stampaVector(){
synchronized(this.list){
for(Integer i:this.list){
System.out.println("StampaVector: "+Thread.currentThread().getName()+" "+i);
}
}
}
public synchronized void stampaVector2(){
for(Integer i:this.list){
System.out.println("StampaVector2: "+Thread.currentThread().getName()+" "+i);
}
}
}
执行stampaVector()的输出:
StampaVector: Thread-0 0
StampaVector: Thread-0 1
StampaVector: Thread-0 2
StampaVector: Thread-0 3
StampaVector: Thread-0 4
StampaVector: Thread-1 0
StampaVector: Thread-1 1
StampaVector: Thread-1 2
StampaVector: Thread-1 3
StampaVector: Thread-1 4
执行stampaVector2()的输出:
StampaVector2: Thread-0 0
StampaVector2: Thread-1 0
StampaVector2: Thread-1 1
StampaVector2: Thread-1 2
StampaVector2: Thread-0 1
StampaVector2: Thread-1 3
StampaVector2: Thread-1 4
StampaVector2: Thread-0 2
StampaVector2: Thread-0 3
StampaVector2: Thread-0 4
对于方法stampaVector2(),我希望获得相同的stampaVector()输出(当时只有一个线程访问列表对象)。
谢谢
最佳答案
当您将synchronized
放在方法上时,您正在this
上进行同步。由于该类有两个实例,每个实例都可以锁定自身,因此都可以同时运行(无阻塞)。
在synchronize this.list
中,两个实例都具有相同的list
实例引用,因此它们都试图获得对单个对象的锁定,因此是互斥的。