目录
<代码块>
(一)JSON
这是一个前后端交互,后续会学到,不用担心。
(二)对象,放在堆空间中
创建子类对象时候本质是先创建父类对象
(三)final关键字
1.用于修饰成员变量(需要初始化)
2.用于修饰局部变量(不需要初始化)
3.不可以重复赋值,只能赋一次值。
4.被final修饰的类和方法不能被继承和重写
(四)final finalize finally的区别
1.性质不同
(1)final为关键字;
(2)finalize()为方法;
(3)finally为为区块标志,用于try语句中;
2.
一.final的用法
被final修饰的类不可以被继承
被final修饰的方法不可以被重写
被final修饰的变量不可以被改变,如果修饰引用,那么表示引用不可变,引用指向的内容可变.
被final修饰的方法,JVM会尝试将其内联,以提高运行效率
被final修饰的常量,在编译阶段会存入常量池中
除此之外,编译器对final域要遵守的两个重排序规则更好:
在构造函数内对一个final域的写入,与随后把这个被构造对象的引用赋值给一个引用变量,这两个操作之间不能重排序,初次读一个包含final域的对象的引用,与随后初次读这个final域,这两个操作之间不能重排序
二.finally的用法
finally是在异常处理中的使用的
不管 try 语句块正常结束还是异常结束,finally 语句块是保证要执行的.
如果 try 语句块正常结束,那么在 try 语句块中的语句都执行完之后,再执行 finally 语句块.
不管有没有出现异常,finally块中的代码都会执行;
当try和catch中有return时,finally仍然会执行;
finally是在return后面的表达式运算后执行的(此时并没有返回运算后的值,而是先把要返回的值保存起来,无论finally中的代码怎么样,返回的值都不会改变,仍然是之前保存的值),所以函数返回值是在finally执行前确定好的;
finally中最好不要包含return,否则程序会提前退出,返回值不是try或catch中保存的返回值.
三.finalize的用法
finalize() 是Java中Object的一个protected方法.返回值为空,当该对象被垃圾回收器回收时,会调用该方法.
关于finalize()函数
finalize不等价于c++中的析构函数;
对象可能不被垃圾机回收器回收;
垃圾回收不等于析构;
垃圾回收只与内存有关;
垃圾回收和finalize()都是靠不住的,只要JVM还没有快到耗尽内存的地步,它是不会浪费时间进行垃圾回收的;
程序强制终结后,那些失去引用的对象将会被垃圾回收.(System.gc())
(五)封装
1.封装的定义及原则:将类的某些信息隐藏在类内部,(所以封装也被称为数据隐藏)不允许外部程序直接访问,而是通过该类提供的方法来实现对隐藏信息的操作和访问。
2.封装的好处:通过方法来控制成员变量的操作,提高了代码的安全性
把代码用方法进行封装,提高了代码的复用性。
(六)继承
1.继承,他就是一个(is-a)的关系,表示一个更特殊的类与一更一般的类之间的关系
2.继承可以让类与类之间产生关系,子父类关系,产生子父类后,子类可以使用父类中非私有的成员
(七)多态
1.多态:即是同一个对象,在不同时刻表现出来的不同形态,多态就是同一个接口,使用不同的实例而执行不同操作。
2.好处:提高程序的扩展性。定义方法的时候,使用父类型作为参数,再使用的时候,使用具体的子类型参与操作
3.弊端:不能使用子类的特有成员
(八)判断是否是所选数据类型
if(引用变量 instanceof 数据类型)