1.整数型 byte----使用byte关键字来定义byte型变量,可以一次定义多个变量并对其进行赋值,也可以不进行赋值。byte型是整型中所分配的内存空间是最少的,只分配1个字节;取值范围也是最小的,只在-128和127之间,在使用时一定要注意,以免数据溢出产生错误。
short----short型即短整型,使用short关键字来定义short型变量,可以一次定义多个变量并对其进行赋值,也可以不进行赋值。系统给short型分配2个字节的内存,取值范围也比byte型大了很多,在-32768和32767之间,虽然取值范围变大,但是还是要注意数据溢出。
int----int型即整型,使用int关键字来定义int型变量,可以一次定义多个变量并对其进行赋值,也可以不进行赋值。int型变量取值范围很大,在-2147483648和2147483647之间,足够一般情况下使用,所以是整型变量中应用最广泛的。
long----long型即长整型,使用long关键字来定义long型变量,可以一次定义多个变量并对其进行赋值,也可以不进行赋值。而在对long型变量赋值时结尾必须加上“L”或者“l”,否则将不被认为是long型。当数值过大,超出int型范围的时候就使用long型,系统分配给long型变量8个字节,取值范围则更大,在-9223372036854775808和9223372036854775807之间。
2.浮点型 float----float型即单精度浮点型,使用float关键字来定义float型变量,可以一次定义多个变量并对其进行赋值,也可以不进行赋值。在对float型进行赋值的时候在结尾必须添加“F”或者“f”,如果不加,系统自动将其定义为double型变量。float型变量的取值范围在1.4E-45和3.4028235E-38之间。
double---double型即双精度浮点型,使用double关键字来定义double型变量,可以一次定义多个变量并对其进行赋值,也可以不进行赋值。在给double型赋值时,可以使用后缀“D”或“d”明确表明这是一个double类型数据,但加不加并没有硬性规定,可以加也可以不加。double型变量的取值范围在4.9E-324和1.7976931348623157E-308之间。
3.布尔型 boolean(true, false):布尔类型又称逻辑类型,只有两个值“true”和“false”,分别代表布尔逻辑中的“真”和“假”。使用boolean关键字声明布尔类型变量,通常被用在流程控制中作为判断条件。
4.字符型 char:char型既字符类型,使用char关键字进行声明,用于存储单个字符,系统分配两个字节的内存空间。在定义字符型变量时,要用单引号括起来,例如‘s’表示一个字符,且单引号中只能有一个字符,多了就不是字符类型了,而是字符串类型,需要用双引号进行声明。
基础数据类型变量和值全部存到栈,所以不能为空。
Java引用类型:
所有的类 所有的数组 所有的接口
补充:Java堆栈:
栈(stack)与堆(heap)都是Java用来在Ram中存放数据的地方。与C++不同,Java自动管理栈和堆,程序员不能直接地设置栈或堆。 栈的优势是,存取速度比堆要快,仅次于直接位于CPU中的寄存器。但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。另外,栈数据可以共 享。堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,Java的垃圾收集器会自动收走这些不再使用的数据。但缺点是,由于要 在运行时动态分配内存,存取速度较慢。
补充:Java中的运算符优先级
1. 赋值不能超过数据类型的范围
public class Test1
{
public static void main(String[] args){
//byte的范围是-128~127
byte b=200;
}
}
注:在Java中,给整数变量赋值时,后面的值会先给一个int
2.强制类型转换:
public class Test1
{
public static void main(String[] args){
//可以在值得前面写一个(byte)让他强制转换
byte b=(byte)200;
System.out.println(b);
}
}
强制转换为byte类型之后,因为200大于了byte类型的最大取值范围127,所以会在从头开始,也就是再从byte类型的最小值-128开始数(200-127)位,得出-56。
3.
public class Test1
{
public static void main(String[] args){
short s=123;
int i=50000;
s=i;
}
}
将i的值赋给s,类型不兼容,int的最大值超过了short的最大的范围
4.
public class Test1
{
public static void main(String[] args){
long i=888;
long l=88888888888;
}
}
88888888888没有超过long的范围,为什么还是会报错?因为将数字赋给一变量时,首先给他一个int类型,而8888888888超过了int的范围所以报错,应该在超出范围的数字后面加一个l声明,l不分大小写。
public class Test1
{
public static void main(String[] args){
long i=888;
long l=88888888888l;
long k=88888888888L;
}
}
5.
public class Test1
{
public static void main(String[] args){
float f=12.345;
}
}
小数变量的值默认为double型,如果需要可以加f进行声明:float f=12.345f; 。
double没有问题。
6.
public class Test1
{
public static void main(String[] args){
char a=98;
System.out.println(a);
}
}
ASCII表:
public class Test1
{
public static void main(String[] args){
short s=123;
char a='a';
System.out.println(s+a);
}
}
在这样的运算中,计算的是它们在ASCII表中的位置的值。
类型转换优先级:
char short byte 进行运算的时候,默认取值为int
显式转换:也叫作强制类型转换,可能会导致精度丢失,精度由高到低,需要声明
隐式转换:精度由低到高,不需要声明
/*
int a = 1, b = 2, c = 3;
等价于
int a;
int b;
int c;
*/
int i = 1, j;
// 等价于
int i = 1;
int j;
float f1 = 0.1;
//0.1默认类型为double,应 float f1 = (float)0.1;
float f2 = 123;
long l1 = 12345678, l2 = 88888888888;
//l2的值超过了默认类型int的范围
double d1 = 2e20, d2 = 124;
byte b1 = 1, b2 = 2, b3 = 129;
//b3的值超过了byte的范围, 应用b3=(byte)129;
j = j + 10;
i = i / 10;
i = i * 0.1;
//应用 i = (int)(i * 0.1);
char c1 = 'a', c2 = 125;
byte b = b1 - b2;
//应改为 int b = b1 - b2; 或者 byte b =(byte) b1 - b2;
char c = c1 + c2 - 1;
// int c = c1 + c2 - 1; 或 char c = (char)(c1 + c2 - 1);
float f3 = f1 + f2;
float f4 = f1 + f2 * 0.1;
//double f4 = f1 + f2 * 0.1; 或 float f4 =(float)( f1 + f2 * 0.1);
double d = d1 * i + j;
float f = d1 * 5 + d2;
//同上
int a, b, c;
a = 2;
b = 'q';
c = 4;
char d = '5';
byte e;
e = a + b;
//e =(byte) a + b;
boolean f = true;
double g = 4.3;
g += b;
b += 0.3;
b = b + 0.3;
//b =(int) b + 0.3;
c += f ? 2 : 4;
float h = 12.5;
//float h =(float) 12.5;
float i = 14.5;
//同上
e = h + i;
e += h;
a += 2147483646;
float j = h / 0.5;
//float j =(float) h / 0.5;