Java中基本数值类型及之间转换

Java是一种强类型语言。这就意味着必须为每一个变量声明一种类型。在Java中,一共有8中基本类型,其中4中整型。、2种浮点类型、1种用于表示Unicode编码的字符单元的字符类型char和1种用于表示真值的boolean类型。
整型
整型用于表示没有小数部分的数值,它允许是负数。Java提供了4种整型,。

类型存储需求取值范围
int4字节-2147 483 648~2147 483 647(正好超过 2亿)
short2字节-32 768~32 767
long8字节-9 223 372 036 854 775 808~9 223 372 036 854 775 807
byte1字节-128~127

长整型数值有一个后缀L或l(如 4000000000L)。十六进制数值有一个前缀0x或者0X(如,0xCAFE)。8进制有一个前缀,例如010代表8 ,很显然8进制特别容易混乱,所以 建议不要 使用8进制常数。从Java7开始,前缀加0b或者0B就可以写2进制。
浮点类型
浮点类型用于表示有小数部分的数值。在Java中有两种浮点类型,

类型储存需求取值范围
float4字节大约±3.40282347E+38F(有效数位6~7位)
double8字节大约±1.79769313486231570E+308(有效位数15位)

取值范围里的E是科学计数法。
double 表示这种类型的数值精度是float类型的两倍(有人称之为双精度数值)。绝大部分应用程序都采用double类型。很多情况下,float类型的精度很难满足需求。实际上,只有很少的情况下适合使用float类型,例如,需要单精度数据的库,或者需要存储大量数据。
float类型的数值有一个后缀F或f(例如,3.14F)。没有后缀F的浮点值(如,3.14)默认为double类型。当然,也可以在浮点数值后加后缀D或d(例如,3.14D)。

char类型:
char类型原本用来表示单个字符。不过,现在情况有所变换。如今,有些Unicode字符可以用一个char值描述,另外一些Unicode字符则需要两个char值
char类型的字面量值要用单引号括起来。
boolean类型:
boolean(布尔)类型有两个值:false和true,用来判定逻辑条件。整型值和布尔值之间不能进行相互转换。

经常需要将一种数值类型转换为另一种数值类型。下图给出了数值类型之间的合法转换。
在这里插入图片描述
在图中有六个实心箭头,表示无信息丢失的转换,有三个虚箭头,表示可能有精度损失的转换。例如,123 456 789 是一个大整数,它所包含的位数比float类型所能够表达的位数多。当将这个整型数值转换为fioat类型丢时,将会得到同样大小的结果,但却失去了一定的精度。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值