博客
关于我
long,double在多线程中的情况
阅读量:393 次
发布时间:2019-03-05

本文共 641 字,大约阅读时间需要 2 分钟。

Java的内存模型确保了基本变量的读写操作是原子操作,但对于64位的long和double类型,JVM将读写操作分解为两个32位操作,这可能导致多个线程读取同一变量时出现数据不一致的情况。为了在线程间共享long和double字段,必须确保可见性和原子性。

可见性与原子性的区别

  • 可见性:volatile确保变量的可见性,所有线程都能看到变量的最新值。例如,一个线程修改了一个非volatile变量,其他线程会立即看到这个变化。

  • 原子性:volatile不保证原子性。即使变量是volatile的,读写操作也可能被分解为多次操作,导致数据不一致。例如,一个long变量会被分解为两个32位操作,可能导致高低位读取不一致。

解决方法

为了保证原子性,需要使用同步机制:

  • synchronized块:通过互斥机制保证线程进入同步块时的原子性操作。
  • Lock对象:使用ReentrantLock或其他锁机制,确保资源的独占访问。
  • 示例

    假设有一个非volatile长变量value,多个线程同时读取和写入。由于长是64位,读写操作会被分解为两个32位操作。例如,线程A读取高位,线程B读取低位,可能导致value不一致。使用synchronized块或Lock对象可以确保在读写时的原子性,避免数据错乱。

    总结

    volatile确保可见性,但不保证原子性。在线程间共享long和double字段时,必须使用同步机制来保证读写操作的原子性。通过结合可见性和原子性,确保多线程环境下的正确性。

    转载地址:http://lyjzz.baihongyu.com/

    你可能感兴趣的文章
    MySQL底层概述—9.ACID与事务
    查看>>
    Mysql建立中英文全文索引(mysql5.7以上)
    查看>>
    mysql建立索引的几大原则
    查看>>
    Mysql建表中的 “FEDERATED 引擎连接失败 - Server Name Doesn‘t Exist“ 解决方法
    查看>>
    MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
    查看>>
    MySQL异步操作在C++中的应用
    查看>>
    MySQL引擎讲解
    查看>>
    Mysql当前列的值等于上一行的值累加前一列的值
    查看>>
    MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
    查看>>
    MySQL必知必会(组合Where子句,Not和In操作符)
    查看>>
    MySQL必知必会总结笔记
    查看>>
    MySQL快速入门
    查看>>
    MySQL快速入门——库的操作
    查看>>
    mysql快速复制一张表的内容,并添加新内容到另一张表中
    查看>>
    mysql快速查询表的结构和注释,字段等信息
    查看>>
    mysql怎么删除临时表里的数据_MySQL中关于临时表的一些基本使用方法
    查看>>
    mysql性能优化
    查看>>
    mysql性能优化学习笔记-存储引擎
    查看>>
    MySQL性能优化必备25条
    查看>>
    Mysql性能优化(1):SQL的执行过程
    查看>>