Java并发编程实战笔记

  • java.util.concurrent.atomic包,封装原子特性—AtomicLong
  • synchronized,方法锁,代码块锁,对应的都是对象锁
    • 对应类继承Runnable接口,或者扩展thread方法,重写run方法
    public synchronized int testSync() throws InterruptedException {
    	for(int i = 0; i < 10; i++) {
    		System.out.println("current thread" + Thread.currentThread().getName());
    		Thread.sleep(1000);
    	}
    	return 0;
    }
    public void run() {
    		testSync();
    }
    Thread t1 = new Thread(thr1);
    t1.start();
    
  • 通过synchronized对对象枷锁,枷锁代码块
    public void testSy() throws InterruptedException {
    	synchronized (a) {
    		for(int i = 0; i < 10; i++) {
    			System.out.println("current thread" + Thread.currentThread().getName());
    			Thread.sleep(1000);
    		}
    	}
    }
    
  • 锁的重入,链路上可以可以嵌套调用同一个锁的多个方法,或者父类方法
  • 同步锁区间不易过大,也不宜过小
  • 非原子64位操作
    • 分高低32为读取,读取的过程中可能存在错位。
  • 锁的行为在于互斥和内存可见,为了确保读到最新值,所有的操作必须在同一个锁上进行同步
  • volatile,原子操作声明,volatile变量不会被缓存到寄存器或不可见的地方,读取的时候总是返回最新的值,包括自身状态可见性,引用对象状态可见性。只保证可见性,不保证原子性,锁既保证可见性,也保证原子性,例如(Cout++)。 如下:变量i加上前缀,i就是线程数的1000倍,否则就会出现无效值。
    volatile int i=0;
    public void testSy() throws InterruptedException {
    	for(int j = 0; j< 1000; j++) {
    		i++;
    	}
    }
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值