java数据类型02_基本数据类型

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)领取。

你可能感兴趣的:(java数据类型02_基本数据类型)