synchronized(object)

package test.thread;

import java.io.IOException;

import org.junit.Test;

/*
 * 测试线程锁
 */
public class TestBlock {
      
        public static void main(String[] args)  {
            /*
                test 多个线程类里 用到的要是同一个 TestBlock对象(该对象只能实例化一次,
                否则实例化多次,就相当于synchronized(this)了,
                对每个不同的实例对象 加了一把锁 并行执行了 这样就错了) 
                这样才能达到 同步阻塞的目的
            */
            TestBlock test = new TestBlock();
            MyTest thread1 = test.new MyTest(test);
            thread1.setName("1");
            MyTest thread2 = test.new MyTest(test);
            thread2.setName("2");
            thread1.start();
            thread2.start();
        }  
    /*
     * 测试同步
     */
    class MyTest extends Thread{
        private Object o;
        
        public  MyTest(Object o){
            this.o=o;
        }
        
        @Override
        public void run() {
            /**
             这个o是test对象的实例 ,对TestBlock类对象实例进行加锁,当线程调用一个实例运行时,
             另外的线程调用这个实例时候阻塞,达到上锁的目的
            */
            synchronized (o) { 
                try {
                    for(int a=0;a<3;a++){
                        System.out.println("线程"+MyTest.currentThread().getName()+"修改a=="+a);
                        //MyTest.yield();
                    }
                } catch (Exception e) {
                    // TODO: handle exception
                }
                
            }
        }
        
    }    
    
}

返回的结果:
  ·      
     
线程1修改a==0
线程1修改a==1
线程1修改a==2
线程1修改a==3
线程1修改a==4
线程1修改a==5
线程1修改a==6
线程1修改a==7
线程1修改a==8
线程1修改a==9
线程2修改a==0
线程2修改a==1
线程2修改a==2
线程2修改a==3
线程2修改a==4
线程2修改a==5
线程2修改a==6
线程2修改a==7
线程2修改a==8
线程2修改a==9
可以看到当一个线程运行完毕之后才运行第二个线程

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值