类对象
我们在前面讲的类定义格式中,“class 类名:”。实际上,当解释器执行 class 语句时, 就会创建一个类对象。
In [1]: class Student:
...: pass
...:
In [2]: print(type(Student))
<class 'type'>
In [3]: print(id(Student))
1779741995168
In [4]: Stu2 = Student
In [5]: print(Stu2)
<class '__main__.Student'>
In [6]: print(type(Stu2))
<class 'type'>
In [7]: print(id(Stu2))
1779741995168
In [8]: stu1 = Stu2()
In [9]: print(type(stu1))
<class '__main__.Student'>
In [10]: print(stu1)
<__main__.Student object at 0x0000019E62878910>
我们可以看到实际上生成了一个变量名就是类名“Student”的对象。我们通过赋值给新变量 Stu2,也能实现相关的调用。说明,确实创建了“类对象”。
类属性
类属性是从属于“类对象”的属性,也称为“类变量”。
由于,类属性从属于类对象,可以 被所有实例对象共享。
类属性的定义方式:
class 类名:
类变量名= 初始值
在类中或者类的外面,我们可以通过:“类名.类变量名”来读写。
class Student:
school = "NWU" #类属性
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.score)
stu = Student('russell', 90)
stu.say_score()
class Student:
school = "NWU" #类属性
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.score)
stu = Student('russell', 90)
stu2 = Student('zhangsan', 60)
stu.say_score()
print('一共创建{0}个 Student 对象'.format(Student.count))
我的学校是: NWU
我的分数是: 90
一共创建2个 Student 对象
类方法
类方法是从属于“类对象”的方法。类方法通过装饰器@classmethod 来定义,格式如下:
@classmethod
def 类方法名(cls [,形参列表]) :
函数体
要点如下:
- @classmethod 必须位于方法上面一行
- 第一个 cls 必须有;cls 指的就是“类对象”本身;
- 调用类方法格式:“类名.类方法名(参数列表)”。 参数列表中,不需要也不能给 cls 传 值。
- 类方法中访问实例属性和实例方法会导致错误
- 子类继承父类方法时,传入 cls 是子类对象,而非父类对象
#测试类方法
class Student:
company = "nwu" # 类属性
@classmethod
def printCompany(cls):
print(id(cls))
print(cls.company)
Student.printCompany()
print(id(Student))
1835745359664
nwu
1835745359664
静态方法
Python 中允许定义与“类对象”无关的方法,称为“静态方法”。
“静态方法”和在模块中定义普通函数没有区别,只不过“静态方法”放到了“类的名字空间里面”,需要通过“类调用”。
静态方法通过装饰器@staticmethod 来定义,格式如下:
@staticmethod
def 静态方法名([形参列表]) :
函数体
要点如下:
- @staticmethod 必须位于方法上面一行 。
- 调用静态方法格式:“类名.静态方法名(参数列表)”。
- 静态方法中访问实例属性和实例方法会导致错误。
class Student2:
company = "nwu" # 类属性
@staticmethod
def add(a, b): # 静态方法
print("{0}+{1}={2}".format(a,b,(a+b)))
return a+b
Student2.add(20,30)
s2 = Student2
s2.add(20,30)