类对象、类属性、类方法(@classmethod)、静态方法(@staticmethod)

类对象

我们在前面讲的类定义格式中,“class 类名:”,实际上,当解释器执行 class 语句时,就会创建一个类对象。

【操作】 测试类对象的生成

class Student:
	pass #空语句,只是作为一个占位符存在。
	
print(type(Student))
print(id(Student))

Stu2 = Student
s1 = Stu2()
print(s1)

执行结果如下:
<class 'type'>
51686328
<__main__.Student object at 0x0000000002B5FDD8>

我们可以看到实际上生成了一个变量名就是类名“Student”的对象。我们通过赋值给新变量 Stu2,也能实现相关的调用。说明,确实创建了“类对象”。

类属性

类属性是从属于“类对象”的属性,也称为“类变量”。由于,类属性从属于类对象,可以被所有实例对象共享。
类属性的定义方式:
  class 类名:
    类变量名= 初始值

在类中或者类的外面,我们可以通过:“类名.类变量名”来读写。

【操作】 类属性的使用测试

class Student:
    school = "Slg" #类属性
    count = 0 #类属性

    def __init__(self,name,score):
        self.name = name #实例属性
        self.score = score
        Student.count = Student.count+1

    def say_score(self): #实例方法
        print("我的学校是:",Student.school)
        print(self.name,'的分数是:',self.score)

s1 = Student("张三",85) #s1 是实例对象,自动调用__init__()方法
s1.say_score()
print('一共创建{0}个 Student 对象'.format(Student.count))

执行结果:
我的学校是: Slg
张三 的分数是: 85
一共创建1个 Student 对象

类方法

类方法是从属于“类对象”的方法。类方法通过装饰器@classmethod 来定义,格式如下:
   @classmethod
   def 类方法名(cls ,[形参列表]) :
     函数体

要点如下:

  1. @classmethod 必须位于方法上面一行
  2. 第一个 cls 必须有;cls 指的就是“类对象”本身;
  3. 调用类方法格式:“类名.类方法名(参数列表)”。 参数列表中,不需要也不能给 cls 传值。
  4. 类方法中访问实例属性和实例方法会导致错误
  5. 子类继承父类方法时,传入 cls 是子类对象,而非父类对象

【操作】 类方法使用测试

class Student:
    school = "Slg" #类属性
    @classmethod
    def printCompany(cls,number):
        print("{0}学生有:{1}".format(Student.school,number))

Student.printCompany(123456)

运行结果:
Slg学生有:123456

静态方法

Python 中允许定义与“类对象”无关的方法,称为“静态方法”。
“静态方法”和在模块中定义普通函数没有区别,只不过“静态方法”放到了“类的名字空间里面”,需要通过“类调用”。
静态方法通过装饰器@staticmethod 来定义,格式如下:
  @staticmethod
  def 静态方法名([形参列表]) :
    函数体

要点如下:

  1. @staticmethod 必须位于方法上面一行
  2. 调用静态方法格式:“类名.静态方法名(参数列表)”。
  3. 静态方法中访问实例属性和实例方法会导致错误

【操作】 静态方法使用测试

class Student:
    company = "SLG" # 类属性
    @staticmethod
    def add(a, b): # 静态方法
        print("{0}+{1}={2}".format(a,b,(a+b)))
        return a+b

Student.add(20,30)

运行结果:
20+30=50

猜你喜欢

转载自blog.csdn.net/weixin_42205723/article/details/88407872