final\finalize\finally
final修饰符该变量被初始化后不能改变
finalize 在对象回收前调用的方法,由线程执行,调用时机无法保证
finally 关键字 与try/catch用于异常处理,一定会被执行,常用于关闭资源
被final
范围 | 结构 |
---|---|
类 | 不可被继承 |
方法 | 不能被重写 |
变量 | 不可修改,表示引用不变,引用指向的内容可变 |
方法 :JVM会尝试将其内联,提高运行效率
常量:置于常量池在编译阶段
重排序?
数据类型相关: int 4字节 char 2字节 float 4字节
byte[]转String : 应用实例内网从外网接收到应用的大小与原应用不符,byte转String(编码可能不同)
Base64编码
encodeBuffer
decodeBuffer
a+b 与a+=b区别
+=会进行隐式自动类型转换a+b 不会
泛型
希望传入类型有一个范围,需要通配符
<?>无限制
<? extends E> 声明了类型的上界,用于灵活读取
<? super E> 下界 用于灵活写入或比较,可写入父类的容器,使父类的比较可应用于子类
总结: 为了获得最大限度的灵活性,要在表示生产者或消费者的输入参数上加上通配符。
规则为:生产者有上限,消费者有下限
GC
如何判断可被回收
引用计数法 | 对象可达性分析 |
---|---|
有互相引用无法GC的问题 | |
JVM中机制分代回收,分别为新生代,老年代和永久代 | |
优先新生代,太大可直接晋升为老年代(分配担保机制) | |
新生代分为eden区和survivor区经历几次回收后仍幸存的晋升老年代 | |
永久代用于存储每个Java类的结构信息,运行常量池、字段和方法数据 | |
根据虚拟机不同。GC可以选择回收或者不回收 | |
新生代标记复制,老年代整理./清理 |
哪些可以做GCRoot
JVM 方法栈中的引用对象
本地方法栈中的引用对象
方法区常量引用对象
方法区类属性的引用对象
进程/线程
线程是CPU调度和分派的基本单位,更小的可独立运行的单位
Callable和Runnnable的区别
Callable | Runnnable |
---|---|
可返回结果 | |
结合Future/Future Task获取异步结果 |
线程阻塞的原因有哪些
Sleep、【suspend和resume(不会自动恢复)】、yield、【wait和notify/notifyall(在synchronized中)】
Synchronized和ReentrantLock
线程生产者和消费者的作用
1)提升运行效率
2)解耦