首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java 中 long 和 double 的原子性?

---- java中基本类型中,long和double的长度都是8个字节,32位(4字节)处理器对其读写操作无法一次完成,那么,JVM,long和double是原子性的吗?...如果使用volatile修饰long和double,那么其读写都是原子操作 对于64位的引用地址的读写,都是原子操作 在实现JVM时,可以自由选择是否把读写long和double作为原子操作 推荐JVM...实现为原子操作 从程序得到的结果来看,32位的HotSpot没有把long和double的读写实现为原子操作。...对于64bit的环境来说,单次操作可以操作64bit的数据,即可以以一次性读写long或double的整个64bit。...因此我们可以猜测,在64位的环境下,long和double的读写有可能是原子操作。

2.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    double转long引发的一次线上故障

    问题背景 问题:部分客户订单页面展示异常问题 原因:double类型转成long类型,精度损失导致线上的故障。...为什么精度会丢失: double类型占用64位 1bit(符号位) 11bit(指数位) 52bit(尾数位) 科学计数法:拿十进制举例子:1.23x10的9次方:1.23就是尾数,9就是指数 所以double...类型表示的数的范围是比long类型要大,但是,由于浮点数是基于科学计数法的,因此它们不能精确地表示某些值,例如非常大或非常小的数字。...建议: 禁止直接将double类型转成long类型,对于一些高精度计算推荐使用BigDecimal BigDecimal是Java中提供的一种高精度数字类型,它可以表示任意精度的十进制数值,计算过程中不会有精度损失...由于BigDecimal类型提供了高精度的数字计算功能,因此通常用于需要精确计算的金融应用程序、科学计算和工程计算等领域。

    1.3K91

    String转为long 类型报错原因:要转为long必须是int、double、float型

    遇到该问题的解决办法一: String strTime = "12.5416132"; double dblTime = Double.parseDouble(strTime); long lngTime...实际上是允许有小数点的出现,但作为long,还是不能parse非整数,此时的a是100.00,是可以丢去小数点作为整数的。...也就是说long在parse的时候是默认把a处理后当成100来parse的。...问题三: 此时的a变成100.1,同样使用了NumberStyles.AllowDecimalPoint,但这时候long所parse的不再是一个整数,所以会提出异常,超过int64也就是long的范围...,对于这个错误,可以先把a=100.1做一个转换变成整形,或者使用范围更广的double或decimal来parse,如decimal.Parse("100.1", NumberStyles.AllowDecimalPoint

    2.4K40

    Java中金额处理选择详解:BigDecimal vs Long vs Double

    Java中金额处理选择详解:BigDecimal vs Long vs Double 金额处理是开发中非常重要的一部分,特别是在金融、电商等涉及交易的系统中。...以下是对三种方式(BigDecimal、Long、Double)的详细分析,以及为什么推荐 BigDecimal 的原因。 1. Double 为什么不适合处理金额?...2.1 使用 Long 的方法 为了避免浮点数的误差问题,许多系统选择用 Long 来存储金额,将小数金额放大 100 倍或 10000 倍(单位为“分”或“厘”),并以整数存储。...2.2 Long 的局限性 操作复杂性增加:每次需要手动管理小数位。...仅在金额简单(如无小数部分)且性能非常敏感的场景下,可考虑 Long。

    19210

    CC++:long int与long long的区别

    大家好,又见面了,我是你们的朋友全栈君。 long int   long int即long,给人的感觉好像是长整型,但实际上,它和int一样,只有32位。...原因是早期的C编译器定义了long int占用4个字节,int占用2个字节,long int是名副其实的长整型。...在ANSI C的标准中,对长整型的定义也是long int应该至少和int一样长,而不是long int 一定要比int占用存储字节长。...long long   long long则不同,long long是C++的64位整型的基本类型,“现任”长整型,从C99开始引入这个概念,在后续的标准中完善概念和定义,C++11官方正式标准如下——...比如说,古老的VC6.0并没有long long这种类型,而__int64的输入输出,又需要printf和%I64d的配合,而不是%lld或者直接用cout。

    2.6K20

    java基本数据类型, byte: short: int: long: float: double: float和double有什么区别 boolean: char:

    long: long 数据类型是 64 位、有符号的以二进制补码表示的整数; 最小值是 -9,223,372,036,854,775,808(-2^63); 最大值是 9,223,372,036,854,775,807...(2^63 -1); 这种类型主要使用在需要比较大整数的系统上; 默认值是 0L; 例子: long a = 100000L,Long b = -200000L。...double: double 数据类型是双精度、64 位、符合IEEE 754标准的浮点数; 浮点数的默认类型为double类型; double类型同样不能表示精确的值,如货币; 默认值是 0.0d;...float和double有什么区别 1、变量类型不同 float属于单精度型浮点数据 double属于双精度型浮点数据。 2、指数范围不同 float的指数范围为-127~128。...double而double的指数范围为-1023~1024 3、表达式指数位不同 float的表达式为1bit(符号位)回+8bits(指数位)+23bits(尾数位) double的表达式为1bit(

    13800

    从硬件角度窥探32位机上Hotspot如何实现volatile修饰的double,long原子性

    仅供参考,如有不妥之处,请多指正 在网上看到许多博客说 java 的 volatile 修饰的 double 和 long 在 32 位机上也是保证原子性的。...但是没有说明为什么,怎么具体实现,是使用互斥量吗,但是要访问的 volatile 修饰的 long,double 变量的地址是随机的,而且数量可能很多 难道要给他们每人配一把 互斥量?...最后要说的是,在 ARM 中,无论是否是 volatile 修饰的 ,long 和 double 都要使用 上述的 ldrexd 和 strexd,所以可以猜测,在 ARM-32 下的hotspot,就算对...long 和 double 不加 volatile 也可以保证写入的原子性(未证实)。...所以在X86下,如果不用volatile 修饰 long 或者 double ,在并发清空下,可能引发一个线程修改了高32位,其他线程读到新的高32位,旧的32位的问题。

    39410

    long double 类型的属性,操作这些值的时候,为什么是分两次完成的

    1 实现 在Java中,对于long和double类型的属性,数值操作分两次完成的原因与它们的内部表示方式有关。 对于long类型,它的内部表示是64位的有符号整数。...这种拆分操作的方式可以确保对long和double类型的数值操作的正确性,同时也会带来一些性能上的开销。...因此,在进行大量的数值操作时,特别是在循环中,尽量避免频繁地对long和double类型的属性进行操作,以提高性能。...需要注意的是,对于long和double类型的属性,由于其拆分操作的特性,可能会导致在多线程环境下出现线程安全问题。...如果多个线程同时对同一个long或double类型的属性进行操作,可能会出现竞态条件和不一致的结果。

    24740

    java integer long 转换_long(Long)与int(Integer)之间的转换

    1.将long型转化为int型,这里的long型是基础类型: long a = 10; int b = (int)a; 2.将Long型转换为int 型的,这里的Long型是包装类型: Long a =...10; int b=a.intValue(); 3.将Long型转换为 Integer 型的,这里的Long型是包装类型: Long a = 10;; Integer b=a.intValue();...4.将int型转化为long型,这里的int型是基础类型: int a = 10;long b = (int)a; 5.将Integer型转化为long型,这里的Integer型是包装类型: int a...= 10;Long b = a.longValue(); 6.将Long型转化为Integer型,这里的Integer型是包装类型: Long a = 10; Integer b=a.longValue...); Integer转int: int i = integer.intValue(); Double转double: double b = Double.doubleValue(); Float转float

    5.4K20

    Java,bit比特,byte字节,char字符,short,int,long,float,double,string,字母,汉字编码等

    ~32,767 有 char 16 ‘\u0000’~’\uffff’ 共有65535个字符表示 无 int 32 -232~232 -1 有 long 64 -264~264-1 有 float 32...有 double 64 双精度浮点型 有 参考网址的话,直接上Oracle的官方文档就好: https://docs.oracle.com/javase/tutorial/java/nutsandbolts...3个或者 4个》》 首先认识下Java中的数据类型: 1、Int整型:byte(8位,-128~127)、short(16位)、int(32位)、long(64位) 2、Float型:float(32...位)、double(64位) 3、char字符:unicode字符(16位) 下面参考了这篇文章: char与byte的区别:http://blog.csdn.net/luoweifu/article...是0—65535; char是一个16位二进制的Unicode字符,JAVA用char来表示一个字符 1、Char是无符号型的,可以表示一个整数,不能表示负数;而byte是有符号型的,可以表示-128

    1.8K20
    领券