java执行流程
Java源码 ---> 编译器 ---->Jvm可以执行的字节码(即虚拟指令)---->jvm ---->jvm中的解释器 ----->机器可以执行的二进制机器码 ----->程序运行
遗忘点01
this和super相关
- this代表当前类,super代表父类
- super()和this()均需要放在构造方法内第一行
- 尽管可以用this调用一个构造器,但是却不能调用两个
- this和Super不能出现在同一个构造函数中,因为this必然会调用其他的构造函数,其他构造函数也必然会有super语句的存在,所以在同一个构造函数里面会有相同的语句,编译器也不会通过。
- this()和super()都指对象,所以均不可以在static环境中。包括static变量、static方法、static语句块
- 从本质上看,this是指向本对象的指针,而Super是java的一个关键字
接口相关
- 接口中也可以实例化对象
- 接口中可以有static方法,并且该方法可以有方法体
- 可以有抽象方法
抽象类相关
变量相关
- 存储位置
- 成员变量: 随着对象的创建而存在,随着对象的消失而消失,存储在堆内存中
- 局部变量:在方法被调用,或者语句被执行的时候存在,存在栈内存中。当方法调用完成,或者语句结束后,就自动释放
- 初始值
- 成员变量:有默认初始值
- 局部变量:没有默认初始值,使用前必须赋值
内部类
- 静态内部类、成员内部类在类中的位置是一样的(类内,成员方法外),容易混乱的地方在与调用方式
Outer outerClass = new Outer()
Outer.Inner inner = outerClass.new Inner();
Outer.StaticInner inner = new Outer.StaticInner();
- 局部内部类:在成员方法内部
- 在成员方法内部new 对象
- 可以访问外部类的所有变量、方法,但是静态的只能访问静态的
Class Outer{
.....
void demo(){
Class Inner{
.....
}
Inner inner = new Inner();
}
}
- 匿名内部类: 没有名字
- 必须实现一个接口或者集成一个抽象类
- 匿名内部类不允许有任何静态成员或者静态方法
- 当所在的方法的形参需要被匿名内部类使用时,必须声明为final。
- 因为生命周期不一样,局部变量的生命周期是,当方法执行完毕之后,普通变量会被释放,而局部内部类对变量的引用还在,此时调用就会报错,加上final,可以是局部内部类使用的变量和外层成员方法的变量分开。(适用成员/匿名内部类)
- 不可以是抽象的,必须要实现继承或者实现接口的所有方法
String相关
private final char value[];
String str = "xxx"
String str = new String("xxx")
- final类,不可以被继承
- 常量池优化:String 对象创建之后,会在字符串常量池中进行缓存,如果下次创建同样的对象时,会直接返回缓存的引用。
- 被多线程共享并频繁访问的时候有利于保持数据一致性。
- 字符串常量池位于堆内存中
- 通过反射可以修改不可变对象
- 使用HashMap也有好处,因为字符串不可变,所以当创建字符串的时候,他的hashcode被缓存下来,不需要再次计算,所以相对于其他对象来说更快。
StringBuilder、StringBuffer
- 两者都继承AbstractStringBuilder,AbstractStringBuilder内部也是用char数组来存的,但是是可变的

- StringBuffer对方法加了同步锁或者对调用的方法加了同步锁,所以是线程安全的。StringBuilder并没有对方法进行加同步锁,所以是非线程安全的。
