一、数据类型--基本数据类型和引用数据类型(阶段二)
先说明两个词汇的基本概念:
bit (位):位是计算机中存储数据的最小单位,指二进制数中的一个位数,其值为“0”或“1”。
byte (字节):字节是计算机存储容量的基本单位,一个字节由8位二进制数组成。在计算机内部,一个字节可以表示一个数据或者一个英文字母,但是一个汉字需要两个字节表示。(关于中文问题可参考:https://how2j.cn/k/io/io-encoding/695.html)
1B=8bit
1Byte=8bit
1KB=1024Byte(字节)=8*1024bit
1MB=1024KB
1GB=1024MB
1TB=1024GB
负数算法:正数的二进制取反加1,如125取反 为 10000010 ,再加1,10000011为-125;
通常情况下,为了方便物品的存储,我们会规定每个盒子可以存放的物品种类,就好比在“放首饰的盒子”里我们是不会放“面包”的!同理,变量的存储也讲究“分门别类”~
Java语言是一种强类型语言。通俗点说就是,在Java中存储的数据都是有类型的,而且必须在编译时就确定其类型。Java中有两类数据类型:基本数据类型(Primitive Type)和引用数据类型(Reference Type)
Java基本数据类型
基本数据类型包括 boolean(布尔型)、char(字符型)、byte(字节型)、short(短整型)、int(整型)、long(长整型)、float(单精度浮点型)、和 double(双精度浮点型)共8种
数据类型封装类
封装类为各个数据类型提供一些数据的操作方法,可以直接使用;
例如String跟int的互相转化:
String a = "21";int b = Integer.parseInt(a);//String 转int。
int a = 21; String b = String.valueOf(a);//int转String。
常用数据类型举例:
(说白了,基本数据类型变量里存储的是直接放在抽屉里的东西,而引用数据类型变量里存储的是这个抽屉的钥匙,钥匙和抽屉一一对应。)在 Java 的领域里,基本数据类型变量存的是数据本身,而引用类型变量存的是保存数据的空间地址。
基本数据类型又可分为 4 大类,即整数类型(包括byte、short,int 和 long)、浮点类型(包括 float 和 double)、布尔类型和字符类型(char)
1)整数类型
Java 定义了 4 种整数类型变量:字节型(byte)、短整型(short)、整型(int)和长整型(long)。这些都是有符号的值,正数或负数。
运行结果:
在该示例中,首先依次定义了 byte 类型、short 类型、int 类型和 long 类型的 4 个变量,并赋予了初始值,然后定义了一个 long 类型、名称为 sum 的变量。sum 变量的值为前 4 个变量之和,最后输出 sum 变量的值,即相加之后的结果。
提示:因为 byte 类型、short 类型、int 类型和 long 类型都是整数类型,故可以使用“+”相加,而非字符串之间的连接。
2)浮点类型
浮点类型是带有小数部分的数据类型,也叫实型。浮点型数据包括单精度浮点型(float)和双精度浮点型(double),代表有小数精度要求的数字。
单精度浮点型(float)和双精度浮点型(double)之间的区别主要是所占用的内存大小不同,float 类型占用 4 字节的内存空间,double 类型占用 8 字节的内存空间。双精度类型 double 比单精度类型 float 具有更高的精度和更大的表示范围。
Java 默认的浮点型为 double,例如,11.11 和 1.2345 都是 double 型数值。如果要说明一个 float 类型数值,就需要在其后追加字母 f 或 F,如 11.11f 和 1.2345F 都是 float 类型的常数。
例如:
声明 float 类型的变量并赋予初值:float price = 12.2f;
声明 double 类型的变量并赋予初值:double price = 12.254d; 或 double price = 12.254;
注意:一个值要能被真正看作 float,它必须以 f(或 F)后缓结束;否则,会被当作 double 值。对 double 值来说,d(或 D)后缓是可选的。
运行结果:
在该示例中,首先定义了一个类型为double、名称为distance的变量用于存储单程距离,然后定义了一个类型为int、名称为num的变量用于存储经过的次数,最后定义了一个类型为float、名称为total的变量用于存储总距离。
其实一个double类型的数据与一个int类型的数据相乘后得到的结果类型为double,但是由于单程距离乘以次数为一个单精度浮点型(float类型)的数,因此可以将总距离转换为float类型的数据。
3)布尔类型
布尔类型(boolean)用于对两个数值通过逻辑运算,判断结果是“真”还是“假”。Java中用保留字true和false来代表逻辑运算中的“真”和“假”。因此,一个boolean类型的变量或表达式只能是取true和false这两个值中的一个。
在Java语言中,布尔类型的值不能转换成任何数据类型,true常量不等于1,而false常量也不等于0。这两个值只能赋给声明为boolean类型的变量,或者用于布尔运算表达式中。
4)字符类型
Java 语言中的字符类型(char)使用两个字节的 Unicode 编码表示,它支持世界上所有语言,可以使用单引号字符或者整数对 char 型赋值。
一般计算机语言使用ASCII编码,用一个字节表示一个字符。ASCII码是Unicode码的一个子集,用Unicode表示ASCII码时,其高字节为0,它是其前255个字符。
Unicode字符通常用十六进制表示。例如“\u0000”~“\u00ff”表示ASCII码集。“\u”表示转义字符,它用来表示其后4个十六进制数字是Unicode码。
字符型变量的类型为char,用来表示单个的字符。
例如:
char letter = 'D';
char numChar = '5';
第一条语句将字符D赋给字符型变量letter,第二条语句将数字字符5赋给字符型变量numChar。
运行结果:
在该示例中,a变量首先被赋值为“A”,字母A在ASCII(和 Unicode)中对应的值为65。接着又定义了一个类型为char的变量b,赋值为“B”,字母B在ASCII(和 Unicode)中所对应的值为66。因此相加后得出的结果为131。
Java引用数据类型
引用数据类型建立在基本数据类型的基础上,包括数组、类(String属于类)、接口、枚举、注解。引用数据类型是由用户自定义,用来限制其他数据的类型。(Java语言中不支持C++中的指针类型、结构类型、联合类型和枚举类型。)
引用类型还有一种特殊的null类型。所谓引用数据类型就是对一个对象的引用,对象包括实例和数组两种。(实际上,引用类型变量就是一个指针,只是Java语言里不再使用指针这个说法。)
空类型(null type)就是null值的类型,这种类型没有名称。因为null类型没有名称,所以不可能声明一个null类型的变量或者转换到null类型。
所有引用类型的默认值都是null。
一个引用变量可以用来引用任何与之兼容的类型。
注意:空引用(null)只能被转换成引用类型,不能转换成基本类型,因此不要把一个null值赋给基本数据类型的变量。