原子操作及线程同步

为了提高性能,在读或写原子数据的时候,应该避免使用同步,这个是非常危险而且错误的,原因参见线程同步的第二条

 原子操作

atomic原子操作是CPU执行指令的最小单元,是指不会被线程调度机制打断的操作;这种操作一旦开始,就一直运行到结束,在执行完毕之前不会被任何其它任务或事件中断。能够在单条指令中完成的操作都可以认为是" 原子操作",因为中断只能发生于指令之间。通常所说的原子操作包括对非longdouble型的primitive进行赋值,以及返回这两者之外的primitive。如果你在longdouble前面加了volatile,那么它就肯定是原子操作了。

 

线程同步

synchronized作用:

1. 互斥:保证一个线程里所看到的都是同一状态,不会出现一个线程执行过程中,共享数据被其他线程修改,引起状态转变,导致一个线程前后看到的东西处于不一致的状况。

2. 同步:保证在一个线程里所做的修改能够被其他线程所看到,避免由于JVM做如下代码优化,所导致多线程不能同步的问题。

    while(!done)

        i++;

JVM优化代码后转换成

    if(!done)

        while(true)

            i++;

    这样的话在另外一个线程修改了done可能会导致while循环永远不会退出,如果使用了synchronized,则不会做此优化,避免了此类问题的发生。

 

总结:当多个线程共享可变数据的时候,每个读或者写数据的线程都必须执行同步。如果只是为了同步(通信),而不是互斥访问,可以用volatile修饰变量,而不用synchronized方法,它可以保证在一个线程中读取的数据都是最新修改的,这样做可以提高性能,因为系统做同步的开销很大。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值