类中不仅可以有 methods,还可以有变量,这些变量称为类属性,例如如下代码中 Book 类的 TYPES 即为类属性。
类中的方法分为3类:
不使用装饰器
类中的所有方法,如果第一个参数是 self,就是 instance method, self 是创建的类实例,实例方法与实例即对象相关。
(self 可以改成别的名称,但使用 self 是convention,self 是类实例, ),
使用 @classmethod 装饰
类方法的第一个参数总是 cls。如果方法需要类的信息,用 @classmethod 对其进行装饰, 类方法经常被用作 factory,例如如下代码中的 hardcover 和 paperback 两个 class method 方法就是可用于创建对象的 factory。
(cls 可以改成别的名称,但使用 cls 是convention)
使用 @staticmethod 装饰
静态方法并不是真正意义上的类方法,它只是一个被放到类里的函数而已。
尽管如此,仍然称之为方法,但它没有关于 class 或 object 的任何信息,所以它实际上是一个独立的函数,只是被放到了类里,静态方法既没有 self 也没有 cls 参数 。(静态方法可以访问类属性,例如 Book.TYPES)
静态方法通常用于组织代码,例如如果认为将某个函数放到某个类里,整体代码会因此更符合逻辑,于是可以将这个函数变成该类的静态方法。所以如果需要在类里放一个函数进去,此函数不会用到任何关于类或实例的信息,那么就可以用 @staticmethod 对其进行装饰。
三种方法中,实例方法和类方法用得最多,静态方法不常用。
class Book: TYPES = ("hardcover", "paperback") # 精装,平装 def __init__(self, name, book_type, weight): self.name = name self.book_type = book_type self.weight = weight def __repr__(self): return f"<Book {self.name}, {self.book_type}, weighing {self.weight}g>" def instance_method(self): print(f"Called instance method of {self}") @classmethod def class_method(cls): print(f"called class method of {cls}") @classmethod def hardcover(cls, name, paper_weight): # cls 名称任意,使用 cls 是 convention # 下一行的cls,改成 Book,代码也能跑,但应该写成 cls, 以避免在 inheritance 可能会遇到的问题 return cls(name, cls.TYPES[0], paper_weight + 100) # @classmethod def paperback(cls, name, paper_weight): # 下一行的cls,改成 Book,代码也能跑,但应该写成 cls, 以避免在 inheritance 可能会遇到的问题 return cls(name, cls.TYPES[1], paper_weight) @staticmethod def static_method(): print("Called static method") book = Book("Dive into Python", Book.TYPES[1], 800) # Called instance method of <Book Dive into Python, paperback, weighing 800g> book.instance_method() # 下一行代码和上一行完全等价 # Called instance method of <Book Dive into Python, paperback, weighing 800g> Book.instance_method(book) # called class method of <class '__main__.Book'> Book.class_method() # Called static method Book.static_method() h_book = Book.hardcover("Harry Potter", 1500) light = Book.paperback("Python 101", 600) # <Book Harry Potter, hardcover, weighing 1600g> print(h_book) # <Book Python 101, paperback, weighing 600g> print(light)
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理