什么叫数据类型?变量的类型定义有什么作用?
数据类型是指数据的类型。
Java中主要有八种基本数据类型:byte、short、int、long、float、double、boolean、char。
各种数据类型作用:
1、byte:
8位、有符号的以二进制补码表示的整数。
min : -128(-2^7)。
max: 127(2^7-1)。
default: 0。
对应包装类:Byte。
2、short:
16位、有符号的以二进制补码表示的整数;
min : -32768(-2^15);
max: 32767(2^15 - 1);
default: 0;
对应包装类:Short。
3、int:
32位、有符号的以二进制补码表示的整数;
min : -2,147,483,648(-2^31);
max: 2,147,483,647(2^31 - 1);
default: 0;
对应包装类:Integer。
4、long:
64位、有符号的以二进制补码表示的整数;
min : -9,223,372,036,854,775,808(-2^63);
max: 9,223,372,036,854,775,807(2^63 -1);
default: 0;
对应的包装类:Long。
5、float:
单精度、32位、符合IEEE 754标准的浮点数;
float 在储存大型浮点数组的时候可节省内存空间;
浮点数不能用来表示精确的值,如货币;
default: 0.0f;
对应的包装类:Float。
6、double:
双精度、64位、符合IEEE 754标准的浮点数;
浮点数的默认类型为double类型;
double类型同样不能表示精确的值,如货币;
default: 0.0d;
对应的包装类:Double。
7、char:
char类型是一个单一的 16 位 Unicode 字符;
最小值是 \u0000(即为0);
最大值是 \uffff(即为65,535);
char 数据类型可以储存任何字符;
对应的包装类:Character。
8、boolean:
boolean数据类型表示一位的信息;
只有两个取值:true 和 false;
这种类型只作为一种标志来记录 true/false 情况;
对应的包装类:Boolean。
扩展资料:
自动类型转换:
指不需要书写代码,由系统自动完成的类型转换。由于实际开发中这样的类型转换很多,所以 Java 语言在设计时,没有为该操作设计语法,而是由 JVM自动完成。
转换规则:从存储范围小的类型到存储范围大的类型。
具体规则为:byte→short(char)→int→long→float→double
也就是说 byte 类型的变量可以自动转换为 short 类型,示例代码:
byte b=10;
short sh=b;
这里在给sh赋值时,JVM首先将b的值转换成short类型然后再赋值给sh。
当然,在类型转换的时候也可以跳跃,就是byte也可以自动转换为int类型的。
注意问题:在整数之间进行类型转换的时候数值不会发生变化,但是当将整数类型特别是比较大的整数类型转换成小数类型的时候,由于存储精度的不同,可能会存在数据精度的损失。
解释:
在冯诺依曼计算机模型中,操作码、操作数以同等地位存储在一起,操作码和操作数都是二进制数据没有区别,计算机由译码器根据数据的位置来辨别操作码、操作数。一个操作数可以作为音频数据也可以作为图像数据也可以作为字符串更可以代表数本身,相等的操作数也可以拥有不等的数据宽度,多个操作数以不同的格局存储在内存中又可以形成不同的数据结构。
现代高级计算机言语中所说的数据,是狭义上宏观上的数据,可能包含一个或n个操作数。因此、必须指明这类数据的使用场景、数据宽度、数据结构,计算机才能通过这些信息结合操作码,准确地使用、存储这些数据,并建立这些数据之间的关系。因此,数据类型应运而生,其作用于各级语言的编译器、解释器。
只是定义变量的类型,才能知道这个变量可以进行什么操作
变量的类型定义了它就会在内存中开辟一个这样大的空间给这个变量来存储啊
变量定义的类型除了决定它在内存中拥有的空间大小以外,还决定它可以存储什么样的数据。比如char型就是存字符,int
就是存整型。各类型之间有时可以转换。比如你可以给一个double型变量附值0(整型)系统会自动换成double.具体的规则就要自己看书了。