1:关键字:被Java语言赋予特定含义的单词
(1)特点:全部小写。
(2)注意事项:
- goto和const作为保留字存在。
2:标识符:就是给类,接口,方法,变量等起名字的字符序列
(1)组成规则:
- 英文大小写字母
- 数字
- $和_
(2)注意事项:
- 不能以数字开头
- 不能是java中的关键字
- 区分大小写
(3)常见的命名规则
A:包 全部小写
单级包:小写
举例:liuyi,com
多级包:小写,并用.隔开
举例:cn.itcast,com.baidu
B:类或者接口
一个单词:首字母大写
举例:Student,Demo
多个单词:每个单词首字母大写
举例:HelloWorld,StudentName
C:方法或者变量
一个单词:首字母小写
举例:name,main
多个单词:从第二个单词开始,每个单词首字母大写
举例:studentAge,showAllNames()
D:常量
全部大写
一个单词:大写
举例:PI
多个单词:大写,并用_隔开
举例:STUDENT_MAX_AGE
3:注释:就是对程序进行解释说明的文字
(1)分类:
A:单行注释 //
B:多行注释 /**/
C:文档注释 /* /
(2)注释的作用
A:解释说明程序,提高了代码的阅读性。
B:可以帮助我们调试程序。
4:常量:在程序执行的过程中,其值不发生改变的量
(1)分类:
A:字面值常量
B:自定义常量
(2)字面值常量
A:字符串常量 “hello”
B:整数常量 12,23
C:小数常量 12.345
D:字符常量 ‘a’,’A’,’0’
E:布尔常量 true,false
F:空常量 null
(4)在Java中针对整数常量提供了四种表现形式
A:二进制 由0,1组成。以0b开头。
B:八进制 由0,1,…7组成。以0开头。
C:十进制 由0,1,…9组成。整数默认是十进制。
D:十六进制 由0,1,…9,a,b,c,d,e,f(大小写均可)组成。以0x开头。
5:进制转换
(1)其他进制到十进制
系数:就是每一个位上的数值
基数:x进制的基数就是x
权:对每一个位上的数据,从右,并且从0开始编号,对应的编号就是该数据的权。
结果:系数*基数^权次幂之和。
(2)十进制到其他进制
除基取余,直到商为0,余数反转。
(3)进制转换的快速转换法
A:十进制和二进制间的转换
8421码。
B:二进制到八进制,十六进制的转换
6:变量
(1)在程序的执行过程中,其值在某个范围内可以发生改变的量
(2)变量的定义格式:
A:数据类型 变量名 = 初始化值;
B:数据类型 变量名;
变量名 = 初始化值;
7:数据类型
(1)Java是一种强类型语言,针对每种数据都提供了对应的数据类型。
(2)分类:
A:基本数据类型:4类8种
B:引用数据类型:类,接口,数组。
(3)基本数据类型
A:整数 (占用字节数)
- byte (1)
- int (4)
- long (8)
B:浮点数
- float (4)
- double (8)
C:字符
- char (2)
D:布尔
- boolean (1)
(4)注意:
整数默认是int类型,浮点数默认是double。
8:数据类型转换
(1)boolean类型不参与转换
(2)默认转换
A:从小到大
B:byte,short,char –> int –> long –> float –> double
C:byte,short,char之间不相互转换,直接转成int类型参与运算
(3)强制转换
A:从大到小
B:可能会有精度的损失,一般不建议这样使用
C:格式:
目标数据类型 变量名 = (目标数据类型) (被转换的数据);
(4)思考题和面试题:
A:下面两种方式有区别吗?
float f1=12.345;
//其实是通过double类型转换过来的, 并不是本来就是float类型
float f1 = 12.345f;
//这个12.345f本来就是float类型
float f2 = (float)12.345;
//强制转换后的结果
B:下面的程序有问题吗,如果有,在哪里呢?
byte b1 = 3;
byte b2 = 4;
byte b3 = b1 + b2;
(byte+byte先提升为int类型,再赋给byte,所以此句有问题,将 int转换为byte)
byte b4 = 3 + 4;
(后面的3、4是常量,常量先相加 ,判断它的值是否在byte类型的表示范围,在就直接是byte类型)