java是一种强类型语言,每个变量都必须声明其类型。
java的数据类型分为两大类:**基本类型**(primitive type)和**引用类型**(reference type)。
# 1. 整数型
整数型常量:
* 十进制整数,例如:123,-100等
* 八进制整数,要求以0开头,例如:015等
* 十六进制整数,要求以0x或0X开头,例如:0x1A,0x15等
数据类型占用存储空间越大,那么表数的范围也就越大。在实际开发中,我们应该根据实际情况选用合适的的数值类型,避免出现超出表数范围的情况(一般情况下我们选用int类型)。
【**注意事项**】
1. 注意数据类型的表数范围,避免出现超出表数范围精度丢失的情况。
2. 整型常量默认为int类型,声明long型常量可以加“l”或“L”,建议使用“L”。
**【扩展知识】**
整型的范围与运行Java代码的机器无关,不需要针对不同的处理器选择最有效的整形。
# 2.浮点型
小数类型在Java中称为浮点类型。
浮点型常量:
* 十进制数形式,例如:3.14 或 123.45
* 科学计数法形式,例如:314E2代表31400.0或314E-2代表3.14
浮点类型分为float类型和double类型:
1. float类型被称作单精度类型,尾数可以精确到7位有效数字,在很多情况下,float类型的精度很难满足需求。
2. double类型被称作双精度类型,数值精度是float类型的两倍,绝大部分应用程序都采用double类型,浮点型常量默认为double类型。
【**注意事项**】
1、 浮点型常量默认为double类型。
2、 浮点型常量赋值给float类型,需要在常量后面添加“f”或 “F”。
3、 避免直接比较两个浮点数的大小,这样比较可能会出现问题。
**【扩展知识】**
整数和浮点数在内存中的存储方式不一样,感兴趣的同学可以自行网上学习。
# 3.布尔型
boolean类型有两个值:true和false。true代表真,false代表假。
boolean类型用来判断逻辑条件,常用于程序流程控制。
**【扩展知识】**
在java规范中,没有明确指出boolean类型所占用的空间大小,深度解读可查阅[这篇博文](https://blog.csdn.net/YuanMxy/article/details/74170745)。
# 4. 字符型
## 4.1字符型
字符型在内存中占有2个字节,在Java中使用**单引号包裹起来的一个字符**称之为字符常量。
例如‘A’是一个字符,它与“A”是不同的,“A”表示含有一个字符的字符串。
【示例】字符型使用
```java
public static void main(String[] args) {
char c1 = 'a'; // 正确,声明并赋值一个'a'字符
char c2 = '安'; // 正确,声明并赋值一个'安'字符
char c3 = '8'; // 正确,声明并赋值一个'8'字符
char c4 = '88'; // 错误,单引号只能包裹一个字符
char c5 = ''; // 错误,单引号包裹的不能一个字符都没有
char c6 = "安"; // 错误,字符只能用单引号包裹,双引号包裹的为字符串
}
```
补充:char类型表示的是Unicode编码表中的字符,所以可以表示一个中文字符。
**char****类型和int类型的联系和区别**
char类型常量在内存中存储的就是Unicode编码值,例如:'A'— 65, '1'— 49。
在一定范围内,char类型和int类型是可以通用的。
【示例】char类型和int类型
```java
public static void main(String[] args) {
char c1 = 'A'; // Unicode对应的数值为65
System.out.println(c1 + 1); // 输出:66
char c2 = 97; // Unicode对应的字符为'a'
System.out.println((char)(c2 - 32)); // 输出:'A'
}
```
char类型和int类型区别:
1、 分配的内存空间不同,int类型占4个字节,char类型占用2个字节。
2、 数值表示的范围不同,int类型标识的范围比char类型更大,并且int类型还可以表示负数。
## 4.2字符集
我们知道计算机只能识别0或1,在计算机中储存的信息都是用二进制数表示的,数值型我们知道该如何转化为2进制然后存储在内存,那么字符型在内存中又是怎么来存储的呢?
本质上字符是没法直接转化为二进制的,我们在屏幕上看到的英文、汉字等字符都是二进制数转换之后的结果。
通俗来说,按照何种规则将字符存储在计算机中,我们称为"**编码**"。例如字符'A'我们可以用十进制65来表示,然后把十进制65转化为二进制后存储在内存中;
反之,将存储在计算机中的二进制数解析显示出来,称为"**解码**"。例如我们从内存中取值的时候,如果取出来的值为十进制65,那么就代表了我们取出来的数据为字符‘A’。
于是乎人类按照以上的“编码”和“解码”规则就创建出了各个语言与之对应的编码表。
字符在内存中的存取:
**常见的字符编码表:**
* ASCII:美国信息交换标准代码,是基于[拉丁字母](https://baike.baidu.com/item/拉丁字母)的一套电脑编码系统,主要用于显示现代的英语和西欧语言的编码表。
* GBK:全称《汉字内码扩展规范》,字库是用来表示中文用的编码。
* Unicode:又称为万国码、统一码,是为了解决传统的编码方案的局限性而产生的,他为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。
Unicode编码,占2个字节,可允许有65536个字符,一个中文字符在内存中占用2个字节。
## 4.3转义字符
Java 语言中还允许使用转义字符来将其后的字符转变为其它的含义。
ps:如需最新的免费文档资料和教学视频,请添加QQ群(627407545)领取。