静态成员变量和普通成员变量内存变化分析
静态成员变量和静态代码块在类加载的时候就初始化,并且代码只跑一次,不管如何new,都不会再跑。静态成员变量的声明有两种,要么在类中,要么在静态代码块中:public class staticTest3 { static staticTest1 p;}
或者public class staticTest3 { static{staticTest1 p;}}
,产生问题:可以在方法中声明一个静态变量吗?答案是不可以的,因为,类加载过程中要初始化静态成员变量和静态变量和静态代码块,而在这个过程还没有生成实例,不存在方法,在一个不存在的东西中放一个存在的东西显然是错误的,这就是为什么静态变量必须是成员变量。至于赋值的话可以在静态代码块或者方法(非静态方法也可以)中。
静态成员变量是共用的,也就是说分配给这个变量存放地址值的空间的地址是不变的,当生成不同staticTest3 实例时,如果多个实例在方法中使用new staticTest1()
,静态变量p存的值,即指向是改变的,但装这些值的地址是不变的,这样的操作就会造成大量的垃圾,因此在给引用赋值时往往要判空。
如果在静态代码块中使用new staticTest1()
,同时没有其他给p赋值的语句,由于代码只跑一次,那么这就不会造成大量垃圾,也不用判空,保证对象唯一。
至于普通成员变量,每生成一个实例就会为该变量分配一个属于该实例的用于存储值的空间。
总结,静态成员变量内存访问公有,普通成员变量内存访问私有。