数据类型
定义
数据类型顾名思义,是指数据的类型。数据类型决定了内存中存储数据的类型及所需内存的大小。
分类
1.基本数据类型:byte、short、int、long、double、float、boolean、char
2.引用数据类型:类、接口、数组、枚举、注解
整型
整型是用来定义整数的关键字,四种整型(byte、short、int、long)都有其表示范围。
Java整形数据类型的有如下4种表示形式:
十进制整数,例如12,-127,0。
二进制整数,以0b开头,例如0b011 (对应于十进制的3 ) (JDK7.0开始)。
八进制整数,以0开头,例如014(对应于十进制的12)。
十六进制整数,以0x或0X开头,例如0XF(对应于十进制的15)。
int age=9;
System.out.println(age);//十进制
age=0b111;
System.out.println(age);//二进制
age=027;
System.out.println(age);//八进制
age=0x1F;
System.out.println(age);//十六进制
常见的四种表示形式。
浮点型
1.浮点型是用来定义小数的关键字。
2.浮点型数据有如下两种表示方式:
十进制形式,例如3.14。
科学计数法形式,例如3.14e1。
注意:
float f = 1.3;是错误的,1.3默认是double型的。在对float数据进行赋值时,要在数字的后面添加f(或F),否则Java编译器会认为1.3是一个double类型的数值,而double不能直接赋值给float类型,故:正确赋值方式应为float f1 = 1.3f;
double price=9.9;
System.out.println(price);//double十进制
price=2.56e2;
System.out.println(price);//科学计数法
float price=9.9f;
System.out.println(price);//float类似于double也有十进制和科学计数法
字符型
字符型采用Unicode编码,一个Unicode编码占2个字节(即16位),由于字符型不存在正负之分,所以其表示范围为0至2的16次方-1(0~65535)。
该种数据类型的变量可以有以下几种赋值方式:
1.使用英文单引号(’)括起单个字符;
2.使用英文单引号括起来十六进制字符代码值来表示单个字符,格式为’\uXXXX’,其中u是约定的前缀,为Unicode的第一个字母。
3.可以直接使用数字表示单个字符。
4.某些特殊的字符可以采用转义符’'来表示,以将其后面的字符转变为其它含义。
char letter=65;
System.out.println(letter);
letter='a';
System.out.println(letter);
letter='\u0041';
System.out.println(letter);
***********************************************************************
char c1 = '\t';//制表符
char c2 = '\n';//换行符-New Line
char c3 = '\r';//回车符-Carriage Return
布尔型
布尔型,又称逻辑类型,只有true和false两个取值,默认初始值为false。这区别与C语言,在C语言标准(C89)没有定义布尔类型,所以C语言判断真假时以0为假,非0为真。
boolean flag=true;
System.out.println(flag);
注意:
在二进制逻辑中Java规定1为真0为假.
基本数据类型转换
1.Java数据类型转换(无论是基本数据类型还是引用类型)分为:
自动类型转换
强制类型转换
2.将表示范围小的数据类型赋值给表示范围大的数据类型时,Java自动使用隐式类型完成数据类型转换.
3.当把级别高的变量赋值给级别低的变量时,必须使用显式类型转换。显示转换格式:(要转换的类型)被转换的值。
float x = 100;//int赋值给float,x的值为100.0
int x = 50; double y; y=x;//int赋值给double,y的为50.0
int x=(int)23.89;//x的值为23
long y=(long)34.98F; ;//y的值为34
byte z = (byte)256;//z的值为0,数据结果出现溢出
注意:
显式类型转化(强制类型转换)可能导致数据精度损失或溢出。