【Java】2 一次性理解java的8种数据类型

数据类型的全家福(4+2+1+1)

java共有8种基本类型(primitive type),其中有4种整型、2种浮点类型、1种字符类型char和1种用于表示真值的boolean类型。

1.整型(4种)

类型存储需求取值范围
int4字节-2 147 483 648~2 147 483 647(削削超过 20亿)
short2字节-32 768 ~32 767
long8字节-9 223 372 036 854 775 808 ~ 9 223 372 036 854 775 807
byte1字节-128 ~ 127
  • 整型用于表示没有小数部分的数值允许是负数。
    • 在通常情况下,int类型最常用。byte和short类型主要用于特定的应用场合,例如,底层的文件处理或者存储空间很宝贵时的大数组。
  • 在Java中,由于Java程序必须保证在所有机器上都能够得到相同的运行结果,所以各种数据类型的取值范围必须固定。整型的范围与运行Java代码的机器无关。
  • 长整型数值有一个后缀Ll;十六进制数值有一个前缀0x0X;八进制有一个前缀0.
  • Java 没有任何无符号(unsigned)形式的int、long、short或byte类型。

2.浮点类型(2种)

类型存储需求取值范围
float4字节大约±3.40282347E+38F(有效位数为6~7位)
double8字节大约±1.797693134 86231570E+308(有效位数为15位)
  • 浮点类型用于表示有小数部分的数值
  • double表示这种类型的数值精度是float类型的两倍(有人称之为双精度数值)
    • float类型的数值有一个后缀Ff(例如3.14F),没有后缀F的浮点数值(如3.14)总是默认为double类型。 当然,也可以在浮点数值后面添加后缀Dd(例如,3.14D)。
  • 所有的浮点数值计算都遵循IEEE754规范。具体来说,下面是用于表示溢出和出错情况的三个特殊的浮点数值:正无穷大负无穷大NaN(不是一个数字)

例如,一个正整数除以0的结果为正无穷大。计算0/0或者负数的平方根结果为NaN。

  • 特别说明:所有“非数值”的值都认为是不相同的。
//不能如下检测一个特定值是否等于Double.NaN
if (x m==Double.NaN) // is never true
//可以如下使用 Double.isNal方法来判断:
if (Double.isNaN(x)) // check whether x is "not a number"

3.char类型(1种)

  • char类型原本用于表示单个字符
    • 如今,有些Unicode字符可以用一个char值描述,一些Unicode字符则需要两个char值。
  • char类型的字面量值要用单引号括起来,如'A'
```java
public static void main(String[] args) {
    char c = 'A';    //字符常量值需要使用单引号囊括,并且内部只能有一个字符
    System.out.println(c);
}
  • 每个数字在计算机中都会对应一个字符,可以去认识一下ASCII码
//英文字母`A`要展示出来,那就是一个字符的形式,
//而其对应的ASCII码值为65,所以说当char为65时,打印出来的结果就是大写的字母A了
public static void main(String[] args) {
    char c = 65;
    System.out.println(c);
}
  • char类型的值可以表示为十六进制值,其范围从\u0000到\uFFFF
    • 除了转义序列\u之外,还有一些用于表示特殊字符的转义序列
转义序列名称Unicode值
\b退格\u0008
"双引号\u0022
单引号\u0027
\t制表\u0009
\n换行\u000a
\反斜杠\u005c
\r回车\u000d
    • 所有这些转义序列都可以出现在加引号的字符字面量或字符串中,如'\u2122'"Hello\n"
    • 转义序列\u还可以出现在加引号的字符常量或字符串之外(而其他所有转义序列不可以),如
public static void main(String[] args)
public static void main(String\u005B\u005D args)
//\u005B和\u005D分别是[和]的编码

1.Unicode转义序列会在解析代码之前得到处理。
例如,"\u0022+\u0022"并不是一个由引号(U+0022)包围加号构成的字符串。实际上,\u0022会在解析之前转换为",这会得到""+"",也就是一个空串。
★2.要当心注释中的\u
// \u000A is a newline会产生一个语法错误,因为读程序时\u00A0会替换为一个换行符
// look inside c:\users也会产生一个语法错误,因为\u后面并没有跟着4个十六进制数。

3.1Unicode和char类型

Unicode打破了传统字符编码机制的限制

在Unicode出现之前,已经有许多种不同的标准

这样就产生了下面两个问题:一个是对于任意给定的代码值,在不同的编码方案下有可能对应不同的字母;二是采用大字符集的语言其编码长度有可能不同。例如,有些常用的字符采用单字节编码,而另一些字符则需要两个或多个字节。

注意: Unicode 是“字符集”,也就是有哪些字符,而UTF-8、UTF-16 是“编码规则”,也就是怎么对这些字符编码,怎么以二进制的形式保存,千万不要搞混了。

4.boolean类型(1种)

  • boolean(布尔)类型有两个值:falsetrue,用来判定逻辑条件。
  • 整型值和布尔值之间不能进行相互转换。
  • 在C++中,数值甚至指针可以代替boolean值。值θ相当于布尔值false,非0值相当于布尔值true。在Java中则不是这样。
    • 因此,Java程序员不会遇到下述麻烦:
if (x = 0) // cops... meant x == 0
//在C++中这个测试可以编译运行,其结果总是false
//在Java中,这个测试将不能通过编译,原因是整数表达式x=0不能转换为布尔值
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员一修

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值