一句话描述就是:方便在没有创建对象的情况下进行调用(方法/变量)。
被static关键字修饰的方法或者变量. 既可以通过对象访问,也可以通过类名访问,但一般更推荐使用类名访问。
static关键字修饰的方法或者变量,不需要依赖于对象来进行访问,只要类被加载了,就可以通过类名去进行访问。
(static 修饰的变量或者方法是一开始就和类一起加载的,所以可以直接通过类名去访问,不用实例化)
static可以用来修饰类的成员方法、类的成员变量,其修饰的成员方法和变量不依赖于对象
代码举例:
public class test02 {
public static void main(String[] args) {
//对于静态修饰的类中的成员变量可以直接通过 类名.成员名 访问
Person.age = 20;
// Person 类中的sleep方法和name变量 未加static ,需要先实例化(new)一个对象才能使用
Person person = new Person();
person.name = "路飞";
person.sleep();
//Person 类中的eat 方法加了static 可以直接用类名进行访问使用
Person.eat();
}
}
class Person {
String name;
static int age;
public static void eat() {
System.out.println( "正在吃饭");
}
public void sleep() {
System.out.println(name+"正在睡觉");
}
}
那 既然static 修饰的变量和方法这么方便,那我们为什么不全都加上呢?
原因::
- 静态方法没有隐藏的this引用参数,因此不能在静态方法中访问任何非静态成员变量,这是很不方便的,需要通过实例化对象,通过对象来访问成员和方法。
public static String getClassRoom(){
System.out.println(this);
return classRoom;
}
// 编译失败:Error:(35, 28) java: 无法从静态上下文中引用非静态 变量 this
public static String getClassRoom(){
age += 1;
return classRoom;
}
- 静态方法中不能调用任何非静态方法,因为非静态方法有this参数,在静态方法中调用时候无法传递this引用
public static String getClassRoom(){
doClass();
return classRoom;
}
// 编译报错:Error:(35, 9) java: 无法从静态上下文中引用非静态 方法 doClass()
3.静态方法是无法被重写的,这就无法形成多态,以及接口的使用。
**注意:**静态成员变量一般不会放在构造方法中来初始化,构造方法中初始化的是与对象相关的实例属性 静态成员变量的初始化分为两种:就地初始化 和 静态代码块初始化。
就地初始化:
就地初始化指的是:在定义时直接给出初始值。
静态代码块初始化
那什么是代码块呢?下面主要对静态代码块和匿名代码块进行介绍:
静态代码块
使用static定义的代码块称为静态代码块。一般用于初始化静态成员变量。
匿名代码块:
主要用于初始化普通的成员变量
下面看下两种代码块的实现语法及执行顺序:
代码举例:
public class Demo01 {
//匿名代码块
{
System.out.println("执行匿名代码块");
}
//静态代码块
static {
System.out.println("执行静态代码块");
}
//构造方法
public Demo01() {
System.out.println( "执行构造方法");
}
public static void main(String[] args) {
Demo01 demo1 = new Demo01();
System.out.println("=========");
//第二次 静态方法不执行
Demo01 demo2 = new Demo01();
}
}
执行结果
执行顺序:
1、静态代码块 :和类一起加载,所以第一个执行 且静态代码块只执行一次
2、匿名代码块 :和对象一起加载,所以第二个执行
3、构造方法 :对象执行时,所以最后一个执行