多线程之二

 线程的同步
The code segments within a program that access the same object from separate, concurrent threads are called “critical sections”。
同步的两种方式:同步块和同步方法
每一个对象都有一个监视器,或者叫做锁。
同步方法利用的是this所代表的对象的锁。
每个class也有一个锁,是这个class所对应的Class对象的锁。

 

class  TicketsSystem
{
     
public static void main(String[] args)
     
{
              SellThread st
=new SellThread();
               
new Thread(st).start();
               
new Thread(st).start();
               
new Thread(st).start();
               
new Thread(st).start();
     }

}

class  SellThread  implements  Runnable
{
     
int tickets=100;
     
public void run()
     
{
             
while(true)
             
{
                     
if(tickets>0)
                     
/**假设第一个线程进入IF语句中,时间片刚好到期,然后第二个线程运行,进入IF语句中
                     时间片刚好到期,然后第三个线程运行,进入IF语句中,时间片刚好到期
                     然后第四个线程运行,进入IF语句中,时间片刚好到期.之后,第一个线程获得时间片,
                     开始运行语句,开始减减,卖了1这张票,tickets变为0,第二个线程卖了0这张票,
                     tickets变为-1.第三个线程卖了-1这张票,tickets变为-2,第四个线程卖了-2这张票,tickets变为-3,
                     让线程睡眠一下,可以捕捉结果
*/

                     
{
                             
try
                           
{
                                   Thread.sleep(
1000);
                           }

                           
catch(Exception e)
                           
{
                                   e.printStackTrace();
                           }

                                   System.out.println(
"obj:"+Thread.currentThread().getName()+
                                                                 
" sell tickets:"+tickets);
                                          tickets
--;
                     }

             }

     }

}

同步块:

 

class  TicketsSystem1
{
     
public static void main(String[] args)
     
{
              SellThread st
=new SellThread();
               
new Thread(st).start();
               
new Thread(st).start();
               
new Thread(st).start();
               
new Thread(st).start();
     }

}

class  SellThread  implements  Runnable
{
     
int tickets=100;
     Object ojb
=new Object();//这个可以是任意的对象
     public void run()
     
{
             
while(true)
             

                     
synchronized(ojb)
                     
/**(这是同步块)当第一个线程达到的时候,首先要判断下OJB的监视器是否加锁了
                     如果没有加的话,它就会给OJB这个对象加锁,然后往下执行,执行到SLEEP的时候,睡眠1秒
                     当第二个线程到达的时候,发现OJB这个对象已经加锁,它只能等待
*/

                     
{
                                 
if(tickets>0)
                                 
/**假设第一个线程进入IF语句中,时间片刚好到期,然后第二个线程运行,进入IF语句中
                                 时间片刚好到期,然后第三个线程运行,进入IF语句中,时间片刚好到期
                                 然后第四个线程运行,进入IF语句中,时间片刚好到期.之后,第一个线程获得时间片,
                                 开始运行语句,开始减减,卖了1这张票,tickets变为0,第二个线程卖了0这张票,
                                 tickets变为-1.第三个线程卖了-1这张票,tickets变为-2,第四个线程卖了-2这张票,tickets变为-3,
                                 让线程睡眠一下,可以捕捉结果
*/

                                 
{
                                         
try
                                       
{
                                               Thread.sleep(
1000);
                                       }

                                       
catch(Exception e)
                                       
{
                                               e.printStackTrace();
                                       }

                                               System.out.println(
"obj:"+Thread.currentThread().getName()+
                                                                             
" sell tickets:"+tickets);
                                                      tickets
--;
                                 }

                         }

             }

     }

}

同步方法:

 

class  TicketsSystem2
{
     
public static void main(String[] args)
     
{
           SellThread st
=new SellThread();
         
new Thread(st).start();         
         
try
      
{
         Thread.sleep(
1000);
      }

      
catch(Exception e)
      
{
           e.printStackTrace();
      }

      st.b
=true;
         
new Thread(st).start();
         
     }

}

class  SellThread  implements  Runnable
{
     
int tickets=100;
     Object ojb
=new Object();//这个可以是任意的对象
     boolean b=false;
     
public void run()
     
{    
           
if(b==false)
           
{
              
while(true)
              

                   sell();
//同步方法利用的是this所代表的对象的锁
              }

          }
   
          
else
          
{
                
while(true)
              

                    
synchronized(this)//能实现方法和同步块同步
         /**静态方法只属于类本身,它并不属于某一个对象,当我们在调用静态方法的时候
            并不需要产生类的对象,同步静态方法使用的是方法所在的类所对应的CLASS对象的监视器,
           每个对象都有自己对应的CLASS对象
*/

                   
//synchronized(ojb)//这样的话。两个线程实现的都是ELSE里的语句,
                   
//让线程睡眠一会可以看到结果会出现0这张票
                   {
                      
if(tickets>0)
                      
{
                           
try
                            
{
                                 Thread.sleep(
1000);
                            }

                            
catch(Exception e)
                            
{
                                 e.printStackTrace();
                            }

                                 System.out.println(
"obj:"+Thread.currentThread().getName()+
                                             
" sell tickets:"+tickets);
                            tickets
--;
                      }

                 }

              }

          }

     }

     
  
public synchronized void sell()
                  
                      
{
                         
if(tickets>0)
                         
/**假设第一个线程进入IF语句中,时间片刚好到期,然后第二个线程运行,进入IF语句中
                         时间片刚好到期,然后第三个线程运行,进入IF语句中,时间片刚好到期
                         然后第四个线程运行,进入IF语句中,时间片刚好到期.之后,第一个线程获得时间片,
                         开始运行语句,开始减减,卖了1这张票,tickets变为0,第二个线程卖了0这张票,
                         tickets变为-1.第三个线程卖了-1这张票,tickets变为-2,第四个线程卖了-2这张票,tickets变为-3,
                         让线程睡眠一下,可以捕捉结果
*/

                         
{
                              
try
                               
{
                                    Thread.sleep(
1000);
                               }

                               
catch(Exception e)
                               
{
                                    e.printStackTrace();
                               }

                                    System.out.println(
"sell:"+Thread.currentThread().getName()+
                                                
" sell tickets:"+tickets);
                               tickets
--;
                         }

                    }

}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值