记录Java多线程的同步问题---synchronized关键字的使用

      多线程的同步依靠的是对象锁机制,synchronized关键字的背后就是利用了封锁来实现对共享资源的互斥访问(一个线程在使用某一个被synchronized标志的对象或者变量或者方法的时候,如果其它线程要使用这个对象--将会处于等待-阻塞状态).

                                                                   同步的关键是多个线程对象竞争同一个共享资源即可!

     基本使用方法:分4种方法介绍

    (1)             public synchronized void run() ...             --------------------用在一个实现了Runnable或者继承了Thread的bean的run()方法中时。  ------------------失败!

                 假如同时new 2个对象并start(),会发现并没有出现互斥现象;

    (2)             private Object lock;                                    --------------------对lock对象使用synchronzied块进行局部封锁,这样就可以让线程去竞争这个唯

                                                              一的共享的对象锁,从而实现同步。                                ------------成功!

                          public MyThread(int id, Object obj)
                             {
                                  
this.threadId = id;
                                 
this.lock = obj;
                             }

                            public  void run() 
                                           {
                                            
synchronized(lock)
                                                         {....}
                                           }

       (3)      private static Object lock = new Object(); ---------------------静态变量是所有类实例对象所共享的,因此线程对象在访问此静态方法时是互斥访

                                                                                                                            问的,从而可以实现线程的同步                                                                         ---------------------成功!

                               run()方法同(2)
       (4)  public  void run()                                              ---------------------静态方法同静态变量                                                                                             ---------------------成功!
                     {
                                  taskHandler(
this.threadId);
                     }
                      
private static synchronized void taskHandler(int threadId)
                     {
                     
for (int i = 0; i < 100++i)
                     {
                         System.out.println(
"Thread ID: " + threadId + " : " + i);
                     }
                     }

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值