静态成员属于类、实例成员属于对象;静态成员在类加载时初始化且被所有实例共享,实例成员每次创建对象时独立生成;静态方法无法访问实例成员,静态方法不参与多态,仅可被隐藏而非重写。

静态成员属于类,实例成员属于对象
静态成员(static 字段或方法)在类加载时就分配内存,且只有一份,被所有实例共享;实例成员每次 new 一个对象时才创建一份,彼此隔离。这意味着改某个对象的实例字段,不影响其他对象;但改静态字段,所有地方都会看到变化。
常见错误现象:NullPointerException 却出现在静态方法里调用实例字段——因为静态方法没有隐式 this,无法访问非 static 成员。
- 静态方法不能直接访问实例变量或调用实例方法(除非显式传入对象引用)
- 实例方法可以自由访问静态和实例成员
-
static块只执行一次,在类首次主动使用时触发
静态成员不参与多态,实例方法才可被重写
Java 中只有实例方法能被子类 override,而静态方法只能被“隐藏”(hide)——即子类定义同签名的 static 方法时,调用行为取决于**编译时类型**,不是运行时对象实际类型。
这容易导致误判:以为写了 @Override 就是重写,结果编译器报错(因为 static 方法不能加该注解),或者运行结果不符合预期。
主要功能说明: 本系统包括 新闻,搜索,留言,会员,社区,博客,相册,交友,聚会,照片,打折,生活,活动,祝福,爱墙,翻唱,黄页,分类,人才,房产,二手,展会,广告管理等功能,全站主要部分生成静态页面,并且超强整合动网论坛最新版,适合于各种地方门户网站、电子商务网站、收费网站等的搭建 后台地址:/Admin/index.asp 初始用户名:Admin 密码:Admin888
立即学习“Java免费学习笔记(深入)”;
- 父类
static void print(),子类也写static void print()→ 是隐藏,不是重写 - 调用
Parent p = new Child(); p.print();执行的是Parent.print() - 调用
((Child)p).print();才执行Child.print(),说明它依赖引用类型而非对象类型
初始化顺序决定静态与实例字段谁先就位
类加载过程有明确阶段:先执行静态变量赋值和静态代码块(按源码顺序),再执行实例变量赋值和构造器(每次 new 时)。这个顺序一旦混淆,就容易出现“静态字段还没初始化就被实例代码读取”的问题。
典型场景:在静态字段初始化中调用了一个实例方法(会报错),或在构造器中提前读取了尚未初始化的静态资源(比如 static final 依赖未完成的计算)。
- 静态变量初始化发生在类加载期,早于任何对象创建
- 实例变量初始化发生在构造器执行前,但晚于静态部分
- 如果静态字段依赖外部配置(如
Properties加载),确保它在static块中完成,而不是靠第一个实例触发
public class Example {
static String s1 = "a";
static {
s2 = "b"; // OK:静态块可赋值给静态字段
// instanceField = "x"; // 编译错误:不能访问实例成员
}
String instanceField = "c";
public Example() {
System.out.println(s1); // OK:静态字段已就绪
System.out.println(instanceField); // OK:实例字段刚初始化
}
static String s2;
}
静态成员和实例成员的根本差异不在语法糖,而在生命周期归属——前者绑定类本身,后者绑定具体对象。只要记住“有没有 this 上下文”,大部分困惑就能定位。









