java - 使用不同对象的同步块(synchronized block)

标签 java synchronization

我们使用什么对象来获取同步块(synchronized block)上的锁真的很重要吗?

例如,我有 2 个代码片段,如下所示。 两者产生相同的输出。我只更改了用于获取同步块(synchronized block)锁定的对象

代码 1:

package test.thread.synchronization;
public class Run1 implements Runnable{
String ts1=null;
public Run1(String ts1){
    this.ts1=ts1;
}
    @Override
public void run() {
    // TODO Auto-generated method stub
    run1Print();
}
public  void run1Print(){
    synchronized(ts1){
    for(int i =0;i<10;i++){
        System.out.println("run1Print: "+Thread.currentThread().getName()+":"+i);
    try{
    Thread.sleep(1000);
    }catch(InterruptedException e){
        e.printStackTrace();
    }
    }
    }
}
}

====

package test.thread.synchronization;
public class Run2 implements Runnable{
String ts1=null;
public Run2(String ts1){
    this.ts1=ts1;
}
@Override
public void run() {
    // TODO Auto-generated method stub
    run2Print();
}
public void run2Print(){
    synchronized(ts1){
//  System.out.println("Decrement");

    for(int i =0;i<10;i++){
        System.out.println("run2Print: "+Thread.currentThread().getName()+":"+i);
    try{
    Thread.sleep(1000);
    }catch(InterruptedException e){
        e.printStackTrace();
    }
    }
    }
}
}

=====

 package test.thread.synchronization;
 public class Ts1 {
public static void main(String[] args) {

    // Ts1 ts1 = new Ts1();
    String ts1 = "";
    Run1 tr1 = new Run1(ts1);
    Run2 tr2 = new Run2(ts1);
    Thread t1 = new Thread(tr1);
    Thread t2 = new Thread(tr2);
    t1.start();
    t2.start();
}

}

代码2:

package test.thread.synchronization;
public class Run1 implements Runnable{
Ts1 ts1=null;
public Run1(Ts1 ts1){
    this.ts1=ts1;
}
@Override
public void run() {
    // TODO Auto-generated method stub
    run1Print();
}
public  void run1Print(){
    synchronized(ts1){
    for(int i =0;i<10;i++){
        System.out.println("run1Print: "+Thread.currentThread().getName()+":"+i);
    try{
    Thread.sleep(1000);
    }catch(InterruptedException e){
        e.printStackTrace();
    }
    }
    }
}
}

======

package test.thread.synchronization;
public class Run2 implements Runnable{
Ts1 ts1=null;
public Run2(Ts1 ts1){
    this.ts1=ts1;
}
@Override
public void run() {
    // TODO Auto-generated method stub
    run2Print();
}
public void run2Print(){
    synchronized(ts1){
//  System.out.println("Decrement");
    for(int i =0;i<10;i++){
        System.out.println("run2Print: "+Thread.currentThread().getName()+":"+i);
    try{
    Thread.sleep(1000);
    }catch(InterruptedException e){
        e.printStackTrace();
    }
    }
    }
}
}

======

package test.thread.synchronization;
public class Ts1 {
public static void main(String[] args) {

     Ts1 ts1 = new Ts1();
    //String ts1 = "";
    Run1 tr1 = new Run1(ts1);
    Run2 tr2 = new Run2(ts1);
    Thread t1 = new Thread(tr1);
    Thread t2 = new Thread(tr2);
    t1.start();
    t2.start();
}

}

最佳答案

对象类型并不重要,但是您应该在唯一的 final 对象上进行同步,否则您可能会无意中让两个线程在两个不同的对象上同步。

关于java - 使用不同对象的同步块(synchronized block),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17748914/

相关文章:

java - 仅在某些输入上附加内容的正则表达式

java - "{}"是什么意思?什么时候 map 是空的?

run() 方法内的 Java 同步

Java 线程 : Should all shared variables be Volatile ?

c++ - 同步对象是否可缓存?

java - 是否有任何理由使所有字段和变量最终化?

java - 如何在groovy中调用java方法

java - 如何使用 List<Entity> 以外的多个属性在 Spring 中返回自定义响应

c# - 同步 pdf 打印和标准打印

c++ - 为什么在 sync_with_stdio(false) 之前使用 cin 给下一个 i/p 变量随机值