类方法用@classmethod装饰,参数为cls,可访问类变量;静态方法用@staticmethod装饰,无默认参数,仅为命名空间工具函数;误用会导致子类不兼容或冗余传参。

类方法和静态方法的区别与使用场景
类方法用 @classmethod 装饰,第一个参数是类本身(通常叫 cls),它能访问类变量、调用其他类方法,但不能直接访问实例属性。适合做与类相关但不依赖具体实例的操作,比如工厂方法、类级别的配置管理。
静态方法用 @staticmethod 装饰,没有默认参数,本质上就是“挂”在类里的普通函数,不访问类或实例状态。适合放一些逻辑上属于该类、但跟类和实例都无数据交互的工具函数,比如日期格式校验、字符串预处理。
常见误用:把本该是实例方法的逻辑写成静态方法,结果需要频繁传入实例对象;或者该用类方法时用了静态方法,导致无法兼容子类重写。
如何正确设计继承关系中的方法重写
子类重写父类方法时,要明确意图:是完全替代(覆盖)、还是增强(调用父类后再扩展)?前者直接重写即可;后者推荐用 super() 调用父类实现,避免硬编码父类名,也方便多继承时方法解析正常。
立即学习“Python免费学习笔记(深入)”;
- 重写 __init__ 时,记得调用 super().__init__(),否则父类初始化逻辑会丢失
- 重写类方法时,super() 返回的是类对象,可继续调用类方法
- 如果父类方法做了关键资源初始化(如打开文件、连接数据库),子类重写时务必保留或显式处理
多重继承与 MRO(方法解析顺序)实战要点
Python 使用 C3 线性化算法确定 MRO,可通过 ClassName.mro() 查看。简单说:子类优先,从左到右,且保证每个父类都在其父类之前。
实际开发中,多重继承不是用来“拼功能”,而是解决正交职责——比如一个类既要可序列化、又要可缓存、还要带日志,就可以分别继承 SerializableMixin、CacheableMixin、LoggableMixin。
注意:Mixin 类应避免定义 __init__,或只接受 **kwargs 并透传给 super(),防止参数冲突。
继承中属性与描述符的协作技巧
当父类定义了描述符(如 @property、自定义描述符),子类可以直接重写同名属性,但要注意:重写 @property 的 setter 或 getter 时,必须同时重写整个 property,或用 super().xxx.fget 等方式复用原逻辑。
如果想让子类“扩展”而非“替换”某个属性行为,更推荐在父类中预留钩子方法(如 _validate_value),子类重写钩子,主 property 保持不变。
静态字段(类变量)被子类继承后,修改子类的同名字段会创建新绑定,不影响父类;但修改可变对象(如列表、字典)的内容,则会影响所有共享该引用的地方。










