synchronized的使用

实例1:

 

public   class  TestSync  implements  Runnable  {
  Timer timer 
= new Timer();
  
public static void main(String[] args) {
    TestSync test 
= new TestSync();
    Thread t1 
= new Thread(test);
    Thread t2 
= new Thread(test);
    t1.setName(
"t1"); //设置线程的名字!
    t2.setName("t2");
    t1.start(); 
//线程开始运行
    t2.start();
    
  }

  
public void run(){
    timer.add(Thread.currentThread().getName());
  }

}


class  Timer {
  
private static int num = 0;
  
public synchronized void add(String name)//synchronized锁定这个方法,线程只有使用完这个方法后,才能使用另一个方法。若不使用synchronized,则不同的线程可以同时使用这个方法。
      
//synchronized (this) {
      for(int i=0;i<2;i++){
          num 
++;  //对于这种多个实例,要想实现同步即输出的数字是有序并且按线程先后顺序输出,我们可以增加一个静态变量,对它进行加锁。
            try {
                Thread.sleep(
1000);
            }
 
            
catch (InterruptedException e)
            
{}
            System.out.println(name
+", 你是第"+num+"个使用timer的线程");
      }

       
      
//}
  }

}

 

实例2:

 

public   class  TT  implements  Runnable  {
    
int b = 100;
    
    
public synchronized void m1() throws Exception{
        
//Thread.sleep(2000);
        b = 1000;
        Thread.sleep(
5000);
        System.out.println(
"b = " + b);
    }

    
    
public synchronized void m2() throws Exception {
        Thread.sleep(
2500);
        b 
= 2000;
    }

    
    
public void run() {
        
try {
            m1();
        }
 catch(Exception e) {
            e.printStackTrace();
        }

    }

    
    
public static void main(String[] args) throws Exception {
        TT tt 
= new TT();
        Thread t 
= new Thread(tt);//创建第一个线程,
        t.start();//第一个线程开始运行
        
        tt.m2();
//第二个线程开始运行
        System.out.println(tt.b);
    }

}

 

实例3:

 

public   class  TestDeadLock  implements  Runnable  {
    
public int flag = 1;
    
static Object o1 = new Object(), o2 = new Object();
    
public void run() {
        System.out.println(
"flag=" + flag);
        
if(flag == 1{
            
synchronized(o1) {
                
try {
                    Thread.sleep(
1000);
                    System.out.println(
"进入了flag=1中");
                }
 catch (Exception e) {
                    e.printStackTrace();
                }

                
synchronized(o2) {
                    System.out.println(
"1");    
                }

            }

        }

        
if(flag == 0{
            
synchronized(o2) {
                
try {
                    Thread.sleep(
500);
                    System.out.println(
"进入了flag=0中");
                }
 catch (Exception e) {
                    e.printStackTrace();
                }

                
synchronized(o1) {
                    System.out.println(
"0");
                }

            }

        }

    }
    
    
    
public static void main(String[] args) {
        TestDeadLock td1 
= new TestDeadLock();
        TestDeadLock td2 
= new TestDeadLock();
        td1.flag 
= 1;
        td2.flag 
= 0;
        Thread t1 
= new Thread(td1);
        Thread t2 
= new Thread(td2);
        t1.start();
        t2.start();
        
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,synchronized关键字用于实现线程之间的同步。它可以应用于方法或代码块上。在方法上使用synchronized关键字,可以确保同一时间只有一个线程可以访问该方法。而在代码块上使用synchronized关键字,可以确保同一时间只有一个线程可以访问被同步的代码块。 在引用中,演示了在同步代码块中使用synchronized关键字的情况。在SynchronizedDemo类的method方法中,使用synchronized关键字来同步代码块,以保证线程安全。 引用展示了子类继承父类,并重写了同步方法的情况。在SynchronizedUsageChild类的synchronizedMethod1方法中,通过使用synchronized关键字来同步方法,确保在多线程环境下,同一时间只有一个线程可以访问该方法。在该方法中,还演示了可重入锁的概念,即子类在同步方法中调用父类的同步方法。 总结来说,synchronized关键字用于实现线程之间的同步,可以应用于方法或代码块上,以确保多线程环境下的线程安全性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Synchronized 详解](https://blog.csdn.net/qq_43322057/article/details/104258758)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Java synchronized使用案例](https://download.csdn.net/download/visionliao/8368107)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [synchronized用法详解](https://blog.csdn.net/ganmaotong/article/details/124501478)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值