基础:
编译(将java语言翻译成JVM的字节码)-运行(JVM运行)
javac.exe编译 java.exe运行。
用记事本写HelloWorld,文件内部的class名要和文件名一样。
启动cmd ,切换到程序所在的父目录H:\java\
dir 可以查看文件
javac以后会产生一个.class文件
一,类的构成
1,类的构造函数,可以有多个,一般一个用来默认构造一个类实例,另一个用来传参初始化一个类实例(参见Java数据结构数组的实现)。
2,变量
局部变量,成员变量,类变量(用staict修饰)
局部变量在方法体内部(方法,构造函数,语句块),生命周期仅在定义的方法体内。如果类需要实例化,一定要在类里面初始化局部变量
成员变量:在类里面,方法体外的变量。可以被修饰符修饰。private修饰的变量可以设置方法设置其值,在类实例化的时候被实例化,(注意是实例化不是初始化,实例化是指,对象.名字可以初始化成员变量有默认值,可以在构造函数里面实例化)。在实例化时传入构造函数里面的变量。
类实例化之后,即类被拷贝了。但是不管实例化了多少变量,静态变量始终都只有一份备份。所以在其中一个实例修改之后在另一个实例上会被影响。
定义变量时,要有修饰符,数据类型,变量名
3,方法
方法传入的参数一定要有数据类型
二,循环语句
return语句之后不会再执行循环,但是return 只能在方法体内
增强for循环语句:
for(元素类型 ele : 数组名/Iterable 实例){ }
实现迭代器Iterable的接口可以作为增强for循环的操作对象。
但是要注意的是:
1、对于数组,foreach 循环实际上还是用的普通的 for 循环
2、对于集合,foreach 循环实际上是用的 iterator 迭代器迭代
对于数组想一边迭代其元素一边调用remove()删除,foreach会报错;但是集合不会这样
这样写就会报错
但是用集合的方法不会报错;
原因:迭代器内部的每次遍历都会记录List内部的modcount当做预期值,然后在每次循环中用预期值与List的成员变量modCount作比较,但是普通list.remove调用的是List的remove,这时modcount++,但是iterator内记录的预期值=并没有变化,所以会报错,但是如果在Iterator中调用remove,这时会同步List的modCount到Iterator中,故不再报错。
参考:https://blog.csdn.net/qq_25622107/article/details/73844509