Java零基础—基本数据类型

程序中有很多数据,每一个数据都是有相关的数据类型的,不同数据类型的数据占用内存空间大小不同。数据类型的作用是指导JVM在运行程序的时候该给数据分配多大的内存空间。

Java中的数据类型包括两种:基本数据类型、引用数据类型。

基本数据类型:

基本数据类型分为四大类:

整数型

byte(字节型):占用1个字节数,取值范围为:-2^{7}~2^{7}-1,即-128~127,默认值为0。

short(短整型):占用2个字节数,取值范围为:-2^{15}~2^{15}-1,即-32768~32767,默认值为0。

int(整型):占用4个字节数,取值范围为:-2^{31}~2^{31}-1,即-2147483648~2147483647,默认值为0。

long(长整型):占用8个字节数,取值范围为:-2^{63}~2^{63}-1,即-9223372036854775808~9223372036854775807,默认值为0,若要什么一个变量为long类型,通常给变量值后面加 l 或 L 。

Java语言整数型常量有三种表示方法:十进制、八进制、十六进制。以int为例:

int a = 123;//十进制,缺省默认的方式
int b = 0123;//八进制,以0开头。
int c = 0x123;//十六进制,以0x开头。

浮点型

Java中浮点型一般默认为double,double与float在计算机中存储的都是近似值。

double a = 3.0;//正常赋值
//float b = 5.1;//编译报错,double类型赋值给float,大容量赋值给小容量,需强制类型转换

float b = (float)5.1//强制类型转换
float c = 5.1f;//编译正常,合法赋值

float(单精度浮点型):占用4个字节数,取值范围大约为\pm 3.40282347\times 10^{38}F(有效位数6~7位),默认值为0.0f。

double(双精度浮点型):占用8个字节数,取值范围大约为\pm 1.79769313486231570\times 10^{308},(有效位数15位),默认值为0.0d。

布尔型

Java中boolean只有true/false两个值,没有别的值,常用于逻辑运算与条件控制语句中。

boolean(布尔型):占用1个字节数,取值范围为 true\false,默认值为false。

字符型

char(字符型):占用2个字节数,取值范围为:0~2^{16}-1,即0~65535,默认值为:'\u0000'。

char的声明:

char a = '1';//声明并赋值
char b = '国';//声明并赋值
a = 'v';//再次赋值

转义字符\:

char a1 = 'n';//普通的字符n
char a2 = '\n';//换行字符
char a3 = '\\';//反斜杠字符
char a4 = '\t';//制表符
char a5 = '\'';//单引号字符
char a6 = '\u4e2d'//汉字"中",\u合起来转义;

注:1byte = 8bit,即1个字节等于8个比特位。

类型转换:

1、八种基本数据类型中除布尔类型之外的7中类型之间都可以相互转换;

2、小容量向大容量转换,称为自动类型转换容量从小到大排序:byte < short \char < int < long < float < double;注:任何浮点类型不管占用多少个字节,都比整数型容量大。char与short可表示的种类数量相同,但是char可以取更大的正整数。

3、大容量向小容量转换,必须添加强制类型转换,程序才可以编译通过,但是可能会损失精度,谨慎使用。

4、当整数字面值没有超出byte、short、char的取值范围,可以直接赋值给byte、short、char类型的变量。

5、byte、short、char混合运算的时候,各自先转成int类型,再做运算。

6、多种数据类型混合运算,先转换成容量最大的那种类型再作运算。

//在字面值不超出byte取值范围内,可以不用强制类型转换,该字面值可以直接赋值给byte。
byte a1 = 127;
//byte a2 = 128; //超出范围,报错
byte a2 = (byte)128; //强制类型转换,损失精度。(原码、反码、补码知识)

long d1 = 12; //int类型的12赋值给long类型的d1,自动类型转换
long d2 = 2147483648; //2147483648默认是整数,超范围,报错:过大的整数。
long d3 = 12L; //不存在类型转换,直接赋值
//int d4 = d3; //编译报错,大容量不能赋值给小容量。
int d4 = (int)d3; //可使用强制类型转换,编译可通过,但是使用强制类型转换可能会损失精度。

double e1 = 10/3; //最后结果为3.0
double e2 = 10.0/3; //最后结果为3.3333333333333335

 

posted on 2020-12-12 22:32  AnYeYiYang  阅读(118)  评论(0编辑  收藏  举报

导航