Java中初级数值类型

JAVA语言与项目相关讨论
发表回复
头像
IOsetting
论坛管理员
论坛管理员
帖子: 3641
注册: 2006-10-17 1:48

Java中初级数值类型

帖子 IOsetting » 2018-12-01 22:32

Java是静态类型语言, 所有的变量必须先声明再使用. 其初级类型一共8种:
  • boolean: 数据只包含1bit信息, 但是占空间为8-bit, 默认值为false
  • byte: 8-bit 带符号补码型整数, 取值 -128 ~ 127. 使用于一些对内存空间敏感的大型数组.
  • char: 16-bit单Unicode字符, 最小值也是默认值, 为'\u0000'(或0), 最大值为'\uFFFF'(或65,535).
  • short: 16-bit 带符号补码型整数, 取值 -32,768 ~ 32,767, 用途同上
  • int: 32-bit 带符号补码型整数, 取值 -231 ~ 231 - 1, 这个值是 2,147,483,648(约21.4亿). 自Java8开始, 可以使用int类型来表示一个无符号32-bit整数, 表示 0 ~ 232 的数值, 具体实现在Integer类中.
  • long: 64-bit 带符号补码型整数, 取值 -263 ~ 263 - 1, 自Java8开始, 也可以通过long类型表示一个无符号64-bit整数, 具体实现在Long类中.
  • float: 单精度32-bit IEEE754浮点数.
  • double: 双精度64-bit IEEE754浮点数.
关于32位JVM和64位JVM
无论是32-bit JVM, 还是 64-bit JVM, 以上数值所占空间都是一样的. 在32位JVM和64位JVM上唯一不同的就是引用(reference)的空间大小. 这是关于32位系统和64位系统的一个误区. 在Oracle Java6 update23以及之后, 对于heap大小在32GB以下的JVM, 默认会使用32-bit的引用. 所以严格来讲, 只有heap在32GB以上的64-bit的JVM, 才会在引用这个类型上有区别.

关于初级数值类型赋值的原子性
对于所有的JVM, 除了long和double, 其他初级数值类型的赋值都是保证原子性的.
在64-bit JVM中, 因为64-bit的引用类型其赋值一定是原子的, 所以对long和double的赋值也应当是原子的.

多线程下的可见度
但即便是保证原子性, 仍然不能保证多线程环境下各线程对数值的"变化可见度", 因为线程在内存中会生成"影子变量", 对一个变量的赋值并不能保证将其写回主内存, 除非在主内存更新时被自动更新. 如果你希望线程间所读取的数值保持一致, 你必须以某种同步壁垒的形式来访问线程间共享的状态. 例如volatile关键字或锁.

发表回复