大家都知道,我们可以基于一个类创建多个该类的对象,每个对象都拥有自己的成员,
互相独立,然而在某些时候,我们更希望该类所有的对象共享同一个成员,此时就是
static 大显身手的时候了。
Java 中被 static 修饰的成员称为静态成员或类成员。它属于整个类所有,而不是
某个对象所有,即被类的所有对象所共享。静态成员可以使用类名直接访问,也可以
使用对象名进行访问。当然,鉴于他作用的特殊性更推荐用类名访问~~
使用 static 可以修饰变量、方法和代码块。
一:static使用之静态变量
例如,我们在类中定义了一个静态变量 className ,操作代码如下所示:
public class HelloWorld {
// 定义静态变量,保存班级名称
static String className = "JAVA开发一班";
public static void main(String[] args) {
// 访问静态变量,通过类名直接访问
System.out.println( HelloWorld.className );
//创建类的对象
HelloWorld hello=new HelloWorld();
//使用对象名访问静态变量
System.out.println( hello.className );
}
}
注意:
静态成员属于整个类,当系统第一次使用该类时,就会为其分配内存空间直到该类被卸载才会进行资源回收!~~
二:static使用之静态方法
与静态变量一样,我们也可以使用 static 修饰方法,称为静态方法或类方法。其实之前我们
一直写的main 方法就是静态方法。静态方法的使用如:
public classHelloWorld {
// 使用static关键字声明静态方法
public static void print(){
System.out.println("欢迎您:xxx!");
}
publicstaticvoidmain(String[] args){
//使用类名直接调用静态方法
HelloWorld.print();
//使用对象名调用静态方法
HelloWorld hello=new HelloWorld();
hello.print();
}
}
需要注意:
1.静态方法中可以直接调用同类中的静态成员,但不能直接调用非静态成员,如果希望在
静态方法中调用非静态变量,可以通过创建类的对象,然后通过对象来访问非静态变量。
2.在普通成员方法中,则可以直接访问同类的非静态变量和静态变量。
3.
静态方法中不能直接调用非静态方法,需要通过对象来访问非静态方法。
三:static使用之静态初始化块
Java 中可以通过初始化块进行数据赋值。如:
public classHelloWorld {
Stringname;//定义一个成员变量
{//通过一个初始化块为成员变量赋值
name="xxx";
}
}
在类的声明中,可以包含多个初始化块,当创建类的实例时,就会依次执行这些代码块。如果使用 static 修饰初始化块,就称为静态初始化块
需要特别注意:静态初始化块只在类加载时执行,且只会执行一次,同时静态初始化块只能给静态变量赋值,不能初始化普通的成员变量
我们来看一段代码:
public classHelloWorld {
String name; // 声明变量name
Stringsex;// 声明变量sex
static int age;// 声明静态变量age
// 构造方法
public HelloWorld () {
System.out.println("通过构造方法初始化name");
name = "tom";
}
// 初始化块
{
System.out.println("通过初始化块初始化sex");
sex = "男";
}
// 静态初始化块
static {
System.out.println("通过静态初始化块初始化age");
age = 20;
}
public void show() {
System.out.println("姓名:" + name + ",性别:" + sex + ",年龄:" + age);
}
public static void main(String[] args) {
// 创建对象
HelloWorldhello= newHelloWorld();
// 调用对象的show方法
hello.show();
}
}
运行结果如下:
通过静态初始化块初始化age
通过初始化块初始化sex
通过构造方法初始化name
姓名:tom,性别:男,年龄:20
通过输出结果,我们可以看到,程序运行时静态初始化块最先被执行,然后执行普通初始化块,
最后才执行构造方法。由于静态初始化块只在类加载时执行一次,所以当再次创建新的对
象时并未执行静态初始化块。