哈哈哈,看了之前的学习总结,才发现没写关键字,今天补一下,先把关键字的内容总结一下吧!后面捎带穿插一些其他知识点,今天写一写关键字final和static ,上一次关于面向对象的多态性放在下一篇文章里!
关键字final
含义是最终的、不变的
final属性和临时变量,一旦赋值则不能修改
(1)属性赋值可以声明的同时直接赋值private final string name="zhangsan";,还可以在构造器或者非静态代码块中进行赋值
class A1{
private final String name="zhangsan";
}
class B1{
prirvate final String name;
public B1(){
name="无参数";
}
public B1(int kk){
name ="整形参数";
}
}
class C1{
private final String name;
{
name ="非静态代码块";
}
}
(2)final 方法不允许子类中覆盖定义
class Parent{
public fianl void pp(){}
}
class Son extends Parent{
public void pp(){}//语法报错,因为父类中pp方法已经声明final类型,不允许修改
}
(3)final类表示这个类不允许被继承
final class Parent{}
class son extends Parent{}//语法报错,因为父类已经声明为fina1类型的,所以不允许定义子类
不允许被继承还可以使用私有构造器的方式来实现【必须所有的构造器都是私有】
注意:String、StringBuilder、StringBuffer是final类,所以不允许定义子类
static关键字
主要用于修饰成员
随着类的加载而产生,随着类的消失而销毁
优先于对象,用类名直接访问
静态属性
所有当前类的这个属性只有一个,所有当前类对象共享这个属性
public class A{
范围限定词[private/package/protected/public] static 类型 变量名;//允许声明的同时赋值
}
//调用方法即可以当作对象的属性进行调用【new A().变量】,也允许通过【类名.变量】的方式进行调用
静态方法
可以通过对象名或者类名调用的方法
public c1ass 类{
范围限定词static 返回值类型方法名称(参数列表){}
}
//调用可以使用【new类().方法名(实参)】调用,也可以使用【类.方法名(实参)】进行调用
(1)在静态方法中不允许使用super或者this指代对象,当然允许在静态方法中自行创建对象进行调用
(2)静态方法只能直接访问静态成员,不能直接访问非静态成员,除非是自行创建对象
静态代码块
实际上就是一个匿名的方法,但是在类加载完成后会自动执行一次。由于匿名只能执行一次。
public class 类{
static{//静态代码块允许定义多次,而且所有的静态代码块在类加载完成后都会自动执行
处理逻辑;
}
}
非静态代码块
实际上就是一个匿名的方法,但是在构建对象之前会自动执行一次。由于匿名只能执行一次。
public class 类{
static{//静态代码块允许定义多次,而且所有的非静态代码块在构造器执行之前都会自动执行
处理逻辑;
}
}
特殊的执行时机
(1)当类加载完毕则会自动优先处理static静态属性和static静态代码块,这两个优先级相同,所以谁在前定义的,先实行谁
(2)new对象时才执行处理非静态属性和非静态代码块,这两个优先级相同,所以谁在前定义的,先实行谁
(3)最后才执行构造器。执行构造器时时先父后子
使用static
(1)当所有成员变量的数据都相同时,可以使用static修改静态属性,从而实现多个对象共享一个静态属性
(2)方法如果访问了特有数据(非静态成员),则这个方法就是非静态的。如果需要方法不持有数据,则方法是静态的。例如Math.abs(-123)
(3)如果类中的所有方法都是静态的,那么构建这个类的对象则是没有任何意义,所以构造器一般会设置为私有的。例如工具类
成员应用细节
JVM主要包括三块内存空间,分别是栈内存、堆内存和方法区
引用和指针的区别:
引用也叫句柄,类似于指针,但是和指针是不同的。指针是一个存放地址的变量,使程序员可以灵活的访问内存,由于可以对指针进行任意的运算操作,所以给程序带来了安全隐患和意想不到的结果。引用继承了指针节省内存的优点,但是限制了对地址的操作,它是安全的。Java中所有的变量都是一个引用, java中没有指针的概念。
栈和堆的区别:
(1)管理方式:栈自动释放,堆需要GC
(2)空间大小:栈比堆小
(3)碎片相关:栈产生的碎片远小于堆
(4)分配方式:栈支持静态和动态分配,而堆仅仅支持动态分配
(5)效率:栈的效率比堆高