Java类声明需选public或默认修饰符,private/protected禁用于顶级类;字段分static(类共享)与非static(实例独有),final字段须在构造器中初始化;构造器无返回类型、不被继承,须显式调用super();this仅用于非static上下文,static方法不可访问实例成员。

类声明和访问修饰符怎么选
Java类最外层是class关键字加类名,但前面的修饰符直接影响类的可见性和用途。不写任何修饰符(默认包级私有)时,该类只能被同一包下的其他类访问;加public后必须与文件名一致,且可被任意位置引用。注意:private和protected不能用于顶级类——编译器会直接报错modifier private not allowed here。
常见误用是想把工具类设为private来“隐藏”,其实应该用final+私有构造器+静态方法组合实现不可实例化。
字段定义要注意初始化时机和内存归属
类里的变量叫字段(field),分static和非static两种。非static字段属于每个对象实例,每次new都会分配新内存;static字段属于类本身,所有实例共享一份。如果在声明时就赋值,比如private String name = "unknown";,这个初始化发生在构造器执行前,但若字段是final且未显式初始化,就必须在构造器里赋值,否则编译失败。
容易忽略的是:字段没加final也不代表能随意改——如果它指向一个可变对象(如ArrayList),外部仍可能通过引用修改其内容,这不是字段本身的可变性问题,而是对象封装没做好。
立即学习“Java免费学习笔记(深入)”;
构造器不是方法,没有返回类型也不能被继承
构造器名字必须和类名完全一致,且不能写void或任何返回类型,否则编译器当成普通方法处理,导致新建对象时调不到预期逻辑。子类不会继承父类构造器,但必须显式或隐式调用super()——如果父类只有带参构造器,子类构造器第一行没写super(...)就会报错constructor Parent() is undefined。
实用建议:
- 多个构造器之间用
this(...)复用,避免重复初始化逻辑 - 参数校验(如判空)应放在构造器开头,而不是等后续方法调用才抛异常
- 不要在构造器里调用可被重写的方法(
overridable method),因为子类对象还没构造完,可能导致字段为null或默认值
方法体里this和static的边界在哪
this指向当前对象实例,只能在非static方法和构造器中使用;一旦方法加了static,就不能直接访问非static字段或方法,否则编译报错non-static variable xxx cannot be referenced from a static context。这不是语法限制,而是语义问题:静态方法属于类,而实例成员属于某个具体对象,两者生命周期和作用域根本不重叠。
典型错误场景:
- 在
main方法(天然static)里直接调getName()而不先new对象 - 把本该操作实例状态的逻辑强行塞进静态方法,结果用一堆静态字段模拟实例行为,破坏面向对象本质
- 误以为
static方法线程安全——其实只是没用实例状态而已,如果它操作了共享静态资源(如static List),照样要同步
类的构成看似简单,但字段、构造器、方法三者之间的所有权关系和调用链稍有错位,运行时表现就可能和预期差很远。尤其在多线程或继承层次深的项目里,搞不清this和static的边界,调试起来特别费劲。










