cls 是什么,作用有哪些?

cls 是什么,作用有哪些?

1. cls 出现在哪里?

cls 是一个约定俗成的参数名称 ,代表类本身 (class)。它类似于 Java 中的 ClassName.class 或静态方法中的类引用。
cls 通常出现在:

  • 类方法@classmethod)的第一个参数
  • __new__ 方法 的第一个参数(__new__ 是一个特殊的静态方法,用于创建实例)

在你给出的代码中:

python 复制代码
def __new__(cls):
    if cls._instance is None:
        cls._instance = super(Database, cls).__new__(cls)
        cls._instance._initialize()
    return cls._instance

这里的 cls 指的就是 Database 这个类本身。


2. cls vs self 的区别

参数 含义 指向 使用场景
self 实例本身 具体的对象 普通实例方法(def method(self):
cls 类本身 类对象(不是实例) @classmethod__new__ 方法

类比 Java

  • selfthis
  • clsDatabase.class 或者静态方法中通过类名直接调用

3. 在单例模式中 cls 的作用

  • cls._instance:相当于 Database._instance,是一个类变量,所有实例共享。
  • super(Database, cls).__new__(cls):调用父类 object__new__ 方法,并传入 cls(即 Database 类),让父类为 Database 类分配内存并创建实例。
  • 整个过程确保只创建一个实例,并且通过 cls 访问和存储这个唯一的实例。

4. 与 Java 的对比

Python Java
cls 作为第一个参数显式传递 类引用隐式可用(如 MyClass.class
@classmethod 中第一个参数是 cls 静态方法中无法访问类的非静态成员,但可以通过类名直接调用
__new__(cls) 是静态方法(隐式),负责创建实例 Java 中用 new 关键字创建实例,无法直接重写 new
通过 cls._instance 访问类变量 通过 MyClass.staticField 访问静态字段

Java 模拟单例的常见写法

java 复制代码
public class Database {
    private static Database instance = null;
    private Database() {}
    public static Database getInstance() {
        if (instance == null) {
            instance = new Database();
        }
        return instance;
    }
}

注意:Java 的静态方法中虽然没有 cls 参数,但可以直接使用类名 Database 来引用类本身,效果类似于 Python 的 cls


5. 总结

  • cls = 类对象 ,类似于 Java 中的 ClassName.class
  • __new__@classmethod 中,cls 由 Python 自动传入,不需要你手动提供。
  • 使用 cls 可以访问类变量、调用其他类方法、创建该类的新实例等。

理解 cls 有助于掌握 Python 的类级别操作,特别是单例模式、工厂方法、元类编程等高级特性。

相关推荐
weixin_397574093 小时前
用自然语言查数据库出图表靠谱吗?一次智能问数实践复盘
数据库
字节跳动开源5 小时前
Viking AI 搜索 CLI 正式发布:会说话,就能做搜索推荐
数据库·人工智能·开源
TechWJ6 小时前
数据库在公司内网,出差路上想查数据怎么办?
服务器·数据库·mariadb
我是一颗柠檬6 小时前
【MySQL全面教学】MySQL事务与ACID Day9(2026年)
数据库·后端·mysql
橙子圆1236 小时前
Redis知识9之集群
数据库·redis·缓存
BlackHeart12036 小时前
【SQL】Oracle中序列(Sequence)作为默认值引发的ORA-00979
数据库·sql·oracle
bug菌7 小时前
【SpringBoot 3.x 第254节】夯爆了,数据库访问性能优化实战详解!
数据库·spring boot·后端
xxl大卡7 小时前
MySQL的执行流程
数据库·mysql
chicheese7 小时前
MySQL优化实践:选错JOIN 驱动表,性能相差几十倍
数据库·mysql
無限進步D7 小时前
MySQL 单行函数
数据库·mysql