定义
是一个值的集合以及定义在这个值集上的一组操作。
理解:
当创建变量的时候,需要在内存中申请空间。
内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据。
因此,通过定义不同类型的变量,可以在内存中储存整数、小数或者字符。
分类:
Java 的两大数据类型:
内置数据类型
引用数据类型
基本数据类型
Java语言提供了八种基本类型.六种数字类型(四个整数型,两个浮点型),一种字符类型,还有一种布尔型.
整型数据byte short int long
byte:
- 数据类型是8位,范围是-128到127(-27到27-1)
- 默认是0,
- byte 类型用在大型数组中节约空间,主要代替整数,因为 byte 变量占用的空间只有 int 类型的四分之一;
例子:byte a = 100,byte b = -50。
short - 数据类型是16位,范围是-32768到32767(-215到215- 1)
- 默认值是 0;
- Short 数据类型也可以像 byte 那样节省空间。一个short变量是int型变量所占空间的二分之一;
例子:short s = 1000,short r = -20000。
int - int 数据类型是32位,范围是 -2147483648到2147483647(-231到231 - 1);
- 一般地整型变量默认为 int 类型;
- 默认值是 0 ;
- 例子:int a = 100000, int b = -200000。
long - long 数据类型是 64 位,范围是 -9223372036854775808到9223372036854775807(-263到263 -1);
- 这种类型主要使用在需要比较大整数的系统上;
- 默认值是 0L;
- 例子: long a = 100000L,Long b = -200000L。
"L"理论上不分大小写,但是若写成"l"容易与数字"1"混淆,不容易分辩。所以最好大写。
浮点型 float double 其实就是小数
float
- float 数据类型是单精度、32位,float 在储存大型浮点数组的时候可节省内存空间;
- 默认值是 0.0f;
- 浮点数不能用来表示精确的值,如货币;
例子:float f1 = 234.5f。
double - double 数据类型是双精度、64 位.浮点数的默认类型为double类型;
- double类型同样不能表示精确的值,如货币;
- 默认值是 0.0d;
例子:double d1 = 123.4。
单精度双精度区别:
- 对于单精度浮点数,运行速度相比double更快,占内存更小,
- 但是当数值非常大或者非常小的时候会变得不精确。
- 2.双精度比单精度表示的位数大 精确的位数多,简单地说, float表示的小数点位数少。
字符char
- char类型是一个单一的 16 位 字符;
- char 数据类型可以储存任何字符;
例子:char letter = ‘A’;
布尔类型boolean
- 只有两个取值:true 和 false;
- 这种类型只作为一种标志来记录 true/false 情况;
- 默认值是 false;
例子:boolean one = true。
引用类型
引用类型String
- String是 java中已经设计好的一个类,表示的值是字符串,是字符串数据类型
- [注意:Java中设计的类和我们自己设计的类的性质是一样的]
常见形式:String s = “你好”
一个类其实就是一种引用数据类型(自定义的类)
- 自己写的一个类也是一种数据类型,类型为类名
枚举
数组
接口