tutorial
java:这个可执行程序其实就是JVM,运行Java程序,就是启动JVM,然后让JVM执行指定的编译后的代码;
javac:这是Java的编译器,它用于把Java源码文件(以.java后缀结尾)编译为Java字节码文件(以.class后缀结尾);
jar:用于把一组.class文件打包成一个.jar文件,便于发布;
javadoc:用于从Java源码中自动提取注释并生成文档;
jdb:Java调试器,用于开发阶段的运行调试。
规范要求
类名要求:类名必须以英文字母开头,后接字母,数字和下划线的组合 习惯以大写字母开头
方法名要求:方法名也有命名规则,命名和class一样,但是首字母小写
常量名通常全部大写
定义变量时,要遵循作用域最小化原则,尽量将变量定义在尽可能小的作用域,并且,不要重复使用变量名
为了避免名字冲突,我们需要确定唯一的包名。推荐的做法是使用倒置的域名来确保唯一性
子包就可以根据功能自行命名
注释
// 单行注释,以双斜线开头,直到这一行的结尾结束
/ / 多行注释
特殊的多行注释,以/*开头,以/结束,如果有多行,每行通常以星号开头
语法
注意到public是访问修饰符,表示该class是公开的。 不写public,也能正确编译,但是这个类将无法从命令行执行
省略变量类型,可以使用var关键字
整数的除法对于除数为0时运行时将报错,但编译不会报错
判断引用类型的变量内容是否相等,必须使用equals()方法:
数据类型
基本类型
整数类型:byte,short,int,long
浮点数类型:float,double
字符类型:char
布尔类型:boolean
引用类型
字符串
数组
class
interface
常量
final
运算
整数运算的结果永远是精确的
整数由于存在范围限制,如果计算结果超出了范围,就会产生溢出,而溢出不会出错,却会得到一个奇怪的结果
在运算过程中,如果参与运算的两个数类型不一致,那么计算结果为较大类型的整型
强制转型使用(类型)
浮点数常常无法精确表示,并且浮点数的运算结果可能有误差
溢出
NaN表示Not a Number
Infinity表示无穷大
-Infinity表示负无穷大
布尔运算
关系运算
比较运算符:>,>=,<,<=,==,!=
与运算 &&
或运算 ||
非运算 !
短路运算 false && x 与运算和或运算是短路运算;
三元运算符 b?x:y 三元运算也是“短路运算”
字符与字符串
双引号"..."表示字符串
一个字符串可以存储0个到任意个字符
使用+连接任意字符串和其他数据类型
字符串可以用"""..."""表示多行字符串(Text Blocks)了
空值null 区分空值null和空字符串"",空字符串是一个有效的字符串对象,它不等于null
数组
数组所有元素初始化为默认值,整型都是0,浮点型是0.0,布尔型是false;
数组一旦创建后,大小就不可改变
Arrays.toString(),可以快速打印数组内容
Arrays.sort()进行排序
数组定义
int[] ns = new int[5];
int[] ns = new int[] { 68, 79, 91, 85, 62 };
int[] ns = { 68, 79, 91, 85, 62 };
遍历数组
java的类型系统结构
type
Class
ParameterizedType
GenericArrayType
WildcardType
Last updated
Was this helpful?