Java定义了八种基本数据类型:byte,short,int,long,char,float,double,boolean。
Java的八种基本类型说明如下所示,其中每一种都有特定的格式和大小 |基本类型|说明|字节数 |:----:|:----:|:----: |byte|字节长度的整数,八位|1个字节 |short|短整数,十六位|2个字节 |int|整数,三十二位|4个字节 |long|长整数,六十四位|8个字节 |float|单精度浮点数,三十二位|4个字节 |double|双精度浮点数,六十四位|8个字节 |char|Unicode字符|2个字节 |boolean|布尔值|1个字节
基本类型的字面值有四种子类型:整数字面值,浮点数字面值,字符字面值,布尔字面值
Java定义了四种整数类型:byte,short,int,long。所有这些类型都是有符号的、正的整数或者负的整数。Java不支持无符号(正值)的整数。博客 名称|宽度|范围 :--:|:--:|:--:| long|64|-9 223 372 036 854 775 808 ~ 9 223 372 036 854 775 807 int|32|-2 147 483 648 ~ 2 147 483 647 short|16|-32 768 ~ 32767 byte|8|-128 ~ 127
当中,最常用的整数类型是int。
整数字面值可以写为十进制,十六进制(加前缀0x或0X),八进制(加前缀0),二进制(加前缀0B或0b)
//十进制
int x=10;
//十六进制数,即十进制的32
int y=0x20;
//八进制,即十进制的15
int z=017;
//二进制,即十进制的7
int u=0b0111;
整数字面值用于将值赋给byte,short,int和long类型的变量。所赋值不能超出变量的存储范围
byte b = 250;
long a = 120;
long a = 99999999999;
如果整数字面值太长,可读性会受到影响。
//十进制
int x=1_000_000;
//十六进制数,即十进制的32
int y=0x2_0;
//八进制,即十进制的15
int z=0_17;
//二进制,即十进制的7
int u=0b0_111;
浮点数也称为实数,当计算需要小数精度的表达式时使用。 名称|宽度|范围 :--:|:--:|:--:| float|32|1.4e-045 ~ 3.4e+038 double|64|4.9e-324 ~ 1.8e+308
float
double
浮点数包含以下四个部分
例如,在1.7e8中,1是整数部分,7是小数部分,8是指数
char是用于存储字符的数据类型。Java的设计初衷是允许程序员编写在世界范围内均可使用的语言,因此采用了Unicode标准来表示字符。Unicode定义了一个完全国际化的字符集,能够表示全部人类语言中的所有字符,为此需要使用十六位宽度来存储。char的范围是0 ~ 65536,没有负的char值。
对于一些语种,例如英语、德语等,可以使用八位宽度来表示这类语言的字符,使用Unicode在一定程度上会降低效率,但这是为了在全球获得可移植性而必须付出的代价。
尽管char被设计为容纳Unicod字符,但也可以用作整数类型,可以对char类型的变量执行算术运算。
字符字面值是一个Unicode字符,或者是单引号括起来的一个转义序列
例如
'a'
'b'
'\b' 回退字符
'\n' 换行
'\r' 回车
布尔类型有两个值,分别为true和false。
例如,声明一个布尔变量bool
boolean bool=true;
在涉及处理不同数据类型时,常常需要将一个变量的值赋给另一个变量,这就需要进行类型转换
默认转换
强制转换
注意要点
!!!!!!!注意!!!!!!!!
1:在java中,任何一个整数默认为 int 类型 (1)
2:在java种,任何一个小数,默认为 double 类型( 1.0)
3:123L 或者 1231 编译器会将该数当成long类型
4:12.345f 或者12.345F 编译器会将该数当成float类型
当从一种基本类型转换向另一种基本类型时,如果后者的大小和前者相同或者更大,就叫做加宽转换
int a=10;
long b=a;
收窄转换发生在从一种基本类型转换为另一种更小类型的转换中
long a=10;
int b=(int)a;
long a=9876543210L;
int b=(int)a;
//输出值是1286608618
System.out.println(b);
除了赋值外,在表达式中也可能会发生类型转换。在表达式中,中间值要求的精度有时会超出操作数的范围。博客
例如:
byte a = 40;
byte b = 50;
byte c = 100;
int d = a * b / c;
中间部分 a b 很容易超出byte操作数的范围。为了解决这类问题,当对表达式求值时,Java会自动将每个byte,short或char操作数提升为int类型。这意味着使用int类型而不是byte类型执行子表达式a b。因此,即时a和b都被指定为byte类型,中间表达式(50 * 40)的结果2000是合法的。
自动类型提升很有用,但有时候会导致难以理解的编译时错误。例如:
byte b=10;
//错误
b= b*2;
如上代码试图将 10 * 2 的结果(一个完全有效的byte值)保存到byte变量中,但是编译器却提示错误。当计算表达式的值时,操作数被自动提升为int类型,所以结果也被提升为int类型。因此,现在是试图将一个int类型值转为byte变量,如果不使用强制类型转换,就不能将结果赋给byte变量。
Java定义了几个应用于表达式的类型提升规则。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。