1
final方法: 该方法不能被覆盖。private的方法默认为final的方法。
2
java 多继承,可以implements不可以extend
3
我们可以像继承类那样继承一个抽象类。
我们必须用完整的方法定义,来覆盖抽象类中的抽象方法,
4
Human aHuman = new Human(160);
其中aHuman是一个引用,存放在stack中,它可以指向其他的对象
Human(160)存在于堆中,是对象本身。
5
abstract类的衍生类必须将abstract类的所有虚方法都实现
否则,衍生类依然是一个抽象类。
6
进程的内存分配:Stack::Heap::Global Data::Instruction
进程的内存分配,当然不是连接的是结合页表结构来理解
7
Stack 用于存放局部变量,函数的参数值等,函数地址
heap 用于存放动态变量 (dynamic variable),对象
Global Data用于存放全局变量。
text 文字常量区
Instruction 存放指令,二进制代码。
8
堆栈的终极区别在哪里,为什么堆栈的读取速度不同?
栈使用的是一级缓存,堆使用的是二级缓存。
栈使用的是先进后出的数据结构,有操作系统来执行释放。
堆使用的是类似链表结构。
9
new操作符的准确说法: 在堆上创建对象
10
自定义类和基本类不同的是,基本类的变量名就是对象本身,不是引用。
11
进行引用的复制并不能复制对象,只是指向同一个对象而已
12
垃圾回收的基本原则是,当存在引用指向某个对象时,那么该对象不会被回收,当没有任何引用指向某个对象时,该对象被清空。它所占据的空间被回收。结合上面的就很好理解了,栈中存储引用名,堆中存储对象,
当栈被清空一部分时就检查对中对象,没有被引用时就清空。(当然没有这么简单)
13
我们在方法内部使用new创建对象,并将该对象的引用返回,如果该返回被一个引用接收,由于对象的引用不为0,对象依然存在,不会被垃圾回收。
14
upcast : 子类型引用=父类型引用
15
object类是所有类的父类。它提供了一些方法。
16
String类是唯一一个不需要new关键字来创建对象的类。
String类对象是不可变对象(immutable object)。
17
程序员不能对已有的不可变对象进行修改。我们自己也可以创建不可变对象,只要在接口中不提供修改数据的方法就可以。然而,String类对象确实有编辑字符串的功能,比如replace()。这些编辑功能是通过创建一个新的对象来实现的,而不是对原有对象进行修改。比如:
s = s.replace(“World”, “Universe”);右边对s.replace()的调用将创建一个新的字符串”Hello Universe!”,并返回该对象(的引用)。通过赋值,引用s将指向该新的字符串。如果没有其他引用指向原有字符串”Hello World!”,原字符串对象将被垃圾回收。
18
要理解 try{throw } catch(){} catch(){} finally{}的作用过程。如果在程序中你没有在 try 中显式的throw,那么肯定在你调用的代码中必有throw