被赋予了特殊java含义的单词。
- 关键字全都是小写
1.行注释:使用 // 来注释一行文字或代码。
//这是行注释的内容
2.块注释: 块前使用 /* ,块后使用 */ 包裹住要注释的块内容
/*这是块注释这是块注释*/
3.文档注释:文档前使用 /** ,文档后使用 */ 包裹文档注释的内容。
/**这是文档注释*/
注释的作用:
- 注解说明程序
- 调试程序
- 常量表示不能改变的数值。代码中直接出现的值。
- java中常量的分类:
- 整数常量。所有整数
- 小数常量。所有小数
- 布尔常量,true或false
- 字符常量。将一个符号,数字或字母用单引号(’’)标识
- 字符串常量。将一个或多个数字,符号或字母用双引号(””)标识
- null常量,只有一个值 即 null,表示空
用来不断的存放同一类型的常量,并可以重复利用
java是强类型语言,对每一种数据都定义了明确的具体数据类型,在内存中分配了不同大小的区域。
整数默认:int 小数默认:double
取值范围:
byte : -128~127 , 1个字节
short: -2^15~2^15-1 ,2个字节
int : -2^31~2^31-1 ,4个字节
long:-2^63~2^63-1 , 8个字节
float : 4个字节
double: 8个字节
char: 0~65535, 2个字节
变量的定义:
byte b = 3;short s = 4000;int x = 12;long l = 1234567890123l;//最后一个字符不是数字1,而是字母Lfloat f = 2.3f;double d = 2.3;char ch = 'a'; boolean bl = true;
整数的类型提升和强制类型转换:
类型提升,如:
int a = 12;byte b = 3;a = a + b;
运算过程:a+b时,由于a为4个字节,b为1个字节,在运算时,java会自动类型提升,并且以a为主,即把b转换为4个字节,前三个字节全为0,再进行相加,结果为4个字节,最后把结果赋值给a。
强制类型转换,如:
int a = 12;byte b = 3;b = (byte)(a + b);运算过程:和上面一样,a+b的结果为4个字节,不能直接赋值给byte类型的b,需要进行强制类型转换,将结果的第一个字节保留后赋值给byte类型的b。要对整数进行强制类型转换,必须确保要转换的值在byte范围之内,否则后丢失数据。
注意:字符型数据和int类型数据运算时,取字符类型数据的Ascii码再和这个int数据运算,结果为int数据。
到这里,我有了一个疑问:在定义和初始化byte类型数据时,byte b = 4; 4不是int类型数据吗?怎么不用强制类型转换,就可以把4赋值给byte类型的变量b。
原因:java在运行byte b = 4这句代码时,编译器会自动判断4这个int型数据是否超过byte型数据所能表示的范围(-128~127)之内,如果4这个数在这个范围内,自动类型转换为byte数据,没有丢失数据;如果4这个数超出这个范围,编译就会报 可能丢失精度的错误。
面试题:下面两个代码为什么出现不同的结果。
1.
byte b = 4;b = 3+7;System.out.PRintln(b);
2.
byte b = 4;byte b1 = 3;byte b2 = 7;b = b1 + b2;System.out.println(b);
结果:第一个代码运行不会报错,第二个会报b = b1 + b2 这句可能损失精度的错误。
原因分析:第一个代码分析同上面疑问的原因,第二个,由于b1和b2是变量,编译器不确定它们的值会不会超出byte表示数据的范围。所以也就检查不了。第一个为常量,可以判断和检查3+7的结果有没有超出byte类型所表示的范围。
联想:以下代码不会报错:
int x ;int x1 = 100;int x2 = 98;x = x1 + x2;System.out.println(x);
原因:int是整数的默认类型。就算这个结果超出了int数据表示的范围,底层也会进行强制类型转换,不管是不是损失精度。
新闻热点
疑难解答