java的重修之路
Posted Dirge
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java的重修之路相关的知识,希望对你有一定的参考价值。
一、内存管理
java里的声明分引用与基本数据类型。
数组:
java里new一个对象数组为 person[] A; A = new person[4]; person[0] = new person();
第一句声明了1个A数组引用变量,指向为null。第二句让A指向一个长度为4的数组内存,数组元素类型是person引用类型,值为null,此时并没有分配内存。所有才有第三句,第三句是真正意义上的分配内存。
java里new多维数组为 int[][] a; a = new int[4][]; a[0] = new int[4];
第一句声明了1个二维数组引用变量,指向为null。第二句声明让a指向一个长度为4的数组内存,数组元素是一维数组引用类型,值为null,此时并没有分配内存。第三句分配了一个长度为4的一维数组,因为数组元素是int,所以变量自动填补为0。(如果把int改为person,则到这里还不够,还需要继续new,为每个person分配内存)。
实例变量与类变量:
被static修饰的是类变量。每个类中有一份类变量,类变量一开始就有内存。所以static方法可以访问static变量,但访问普通变量必须先new,因为普通变量没有分配内存。
对于类变量,系统首先为其分配内存空间,并将基本数据类型赋值为0或null;之后再根据初始化顺序依次初始化。
父子实例的内存控制:方法会覆盖,变量不不会被覆盖。这里就牵扯到多态问题了。一个父类引用指向一个子类变量时,当用该引用调用方法 引用.方法(),调用的是实际类型的方法(子类方法);当用该引用调用变量时 引用.变量,调用的是声明类型的方法(父类方法)。
final修饰符:
很多情况下,final修饰的变量会被当做宏替换处理。子类若能访问到父类的final方法,则不能对final方法进行重写。
内部类:成员内部类、静态内部(嵌套)类、方法内部类、匿名内部类 。
成员内部类:
以上是关于java的重修之路的主要内容,如果未能解决你的问题,请参考以下文章