类是模板,对象是实例;类无状态不能直接调用非静态成员,new才生成独立对象并分配堆内存,引用传递导致共享修改,需警惕空指针与数据污染。

类不是对象,也不能当对象用
Java里Person类本身不能调用sayHello(),也不能读写name——它只是个模板,没数据、没内存地址。你写Person.name或Person.sayHello(),编译直接报错,除非那个成员被声明为static。
- 只有
new Person()之后产生的实例(比如p1、p2)才真正拥有自己的name值和可执行的sayHello() -
static是例外,但它属于“类级别”,脱离了对象上下文,访问不了this.name这类非静态成员 - 常见错误:在工具类里误把业务逻辑写成静态方法,结果要传一堆参数才能模拟对象状态,反而更难维护
new 一次,堆里就多一块独立内存
执行Person p = new Person()时,JVM干三件事:加载Person类信息到方法区(只做一次)、在堆中分配空间并设默认值(int→0、String→null)、再把这块堆地址赋给栈变量p。
- 每个
new出来的对象,属性互不干扰——改p1.name绝不会影响p2.name - 如果忘了
new,比如只写Person p;就去p.name = "Alice",运行时抛NullPointerException - 大量短生命周期对象(如循环里反复
new String())会加重GC压力,不是所有地方都适合无脑实例化
类定义共性,对象承载个性
类描述“人有什么”和“能做什么”,对象决定“这个人叫什么”和“现在正在说什么”。就像Car类定义了color、brand、start(),但tesla.color = "红色"和bmw.color = "黑色"才是真实差异的来源。
- 字段没初始化时,数值型是
0或0.0,引用类型是null,别依赖“自动清空” - 构造方法不是必须写,但一旦写了带参构造,无参构造就不再默认提供,容易导致子类或框架(如Spring)注入失败
- 不要在类里直接操作具体值(比如写
System.out.println("张三说…")),那会把模板写死,失去复用意义
对象之间靠引用来传递,不是复制
你写Person p1 = new Person(); Person p2 = p1;,p2拿到的不是新对象,而是同一块堆内存的另一个名字。改p2.name,p1.name也会变。
立即学习“Java免费学习笔记(深入)”;
- 想真正复制一个对象,得手动逐字段赋值,或实现
Cloneable接口,或用构造函数传参重建 - 集合类(如
ArrayList<person></person>)存的也是引用,遍历时修改元素内容会影响原对象 - 跨方法传对象时,方法内部改它的字段,调用方能看到变化;但若在方法里重新
new一个并赋给形参变量,原引用不受影响——这点初学者最容易混淆









