关于Java中的static关键字的用法
static关键字修饰的常见元素
-
成员变量(千万要注意不能修饰局部变量)
-
成员方法
-
代码块
在Java中被static关键字修饰会产生一些特殊性。为了便于理解,先了解静态内存。如下图:
PS:由内存图可以看出,被static关键字修饰的东西,会在存一个静态存储区 -
首先来看修饰成员变量的情况:
原因:有些属性不是属于某个对象的,而是属于整个类的。比如要设计一个在类:“一个在黑马程序员(校名)毕业的类”。这个时候所有创建出来的对象都是使用相同的数据:校名(黑马程序员)
目的:在静态内存中只有一份,节省内存,因为这个数据就不需要每次在创建对象时,在多创建这个数据。
使用:类名.属性名
- 修饰成员方法的情况:(原因和目的我们已经知道了)
回顾:普通方法的使用,必须要创建对象,然后“对象.方法名()”
优点:在我们调用时,不需要创建对象,直接用 “ 类名.方法名()”,方便省事
缺点:当方法被static修饰后,方法体内只能使用被static修饰的内容(因为他们存储的地方都在静态区)
为了看得清楚请看以下代码:
主类:
测试类:
请看主类中被static修饰的daKa()方法。无论是本来还是其他类,只要没有被static修饰,在方法内都无法使用。相反,在测试类中,被static修饰后的show1()方法则可以被使用。
- 修饰代码块的情况:
先看以下代码: - 平时我们都知道在测试类中定义一个main来作为程序入口,经常会忽略静态代码块。
以下是程序运行的结果: - 程序找到main方法后,其实是先找到该类中的静态代码块执行,然后再执行main方法。
- 在该方法中创建的两个Person对象,但过程中,静态代码块内容只输出一次,说明静态代码块只会在类的第一次使用时候才会被加载,并且只使用一次。