面向对象最重要的概念应该就是类(class)和实例(instance)了。记得以前学习java的时候,有一个比较简单的例子来解释类和实例。
在汽车制造过程中,我们需要先设计图纸,让后再根据图纸来制造实际的汽车。类就相当于图纸,而实例则是实际的汽车。一张图纸可以造出很多汽车,刚造出的汽车是一样的,但是后续可以进行个性化的改装。
python可以根据class在内存中创建多个实例,每个实例可以独立地添加和修改方法和属性。
class Car(Vehicle): pass
我们来说明一下, class
关键词来声明这是一个类,紧接着就是类名。后接一个 ()
,里面是该类所继承的父类。
在2.7中,一个类如果没有继承其它类,则可以另其继承 object
类。那么这样定义的就是一个 new style object
,即新式类。
如果不声明继承自何类,那么定义的则是经典类。
例如:
# 定义新式类 class Student(object): pass # 定义经典类 class Student2: pass
新式类和经典类的区别出了写法不一样外,还存在其它区别:
新式类的类型是 type
,经典类的类型是 classobj
。新式类的出现就是为了将所有类的类型统一为 type
。
对于多继承,继承搜索的顺序发生了改变。 (这里不懂)
默认属性发生了改变
可能还有其它
Python 3.x以上版本所有的类均是新式类,不需要显式地继承 object
。
类中可以定义一个构造函数 __init__
。构造函数的意思就是类在创建的时候会执行的函数。 __init__
函数的第一参数是 self
,指实例本身。 __init__
函数还可以有多个参数,这些参数需要在实例创建的时候传入。
例如:
class Student(object): def __init__(self, name, age, gender): self.name = name self.age = age self.gender = gender
__init__
函数经常用于对实例属性进行初始化。
类中的函数也叫做方法。方法与其它函数有所区别,即方法的第一个参数永远是 self
,即实例本身。
创建实例后,在调用方法是,并不需要传入实例,因为编译器为自动为我们加入实例。例如:
class Student(object): def __init__(self, name, age, gender): self.name = name self.age = age self.gender = gender # 方法的第一个参数是self def print_name(self): print self.name student = Student("charlie", 20, 'male') #调用函数的时候,并不需要手动传入实例student student.print_name()
classmethod和staticmethod。
简单粗浅地说,可以理解成:
classmethod的是定义一些仅仅跟类有关,但是跟实例无关的方法。
staticmethod是一些跟类有关系的功能,但是其具体的实现却又不需要用到类或者实例的参与。staticmethod叫做静态方法。
更多解释和例子,可以阅读知乎上的回答: https://www.zhihu.com/questio...
属性就更加好理解了。
例如我们设计一张制造冰箱的图纸,我们除了定义冰箱的功能(类的方法)外,还需要定义冰箱的颜色、长、宽、高、等属性。类也一样。
class Fridge(object): color = 'yellow' height = 120 width = 30 food = 'fish' def storage(self): print "keep %s fresh" % self.food fridge = Fridge() fridge.storage()
上面我们讲了这么多类的特性,其实类就是一个数据类型。我们把一种数据类型封装成一个类。
例如一个学生具有姓名、年龄、性别等属性,另外他也有书写姓名、读书识字等功能。我们可以把一个Student所有的属性和功能看成一个整体,那么这就是一个类。这个类就是与python中内置的其它数据类型一样的数据类型,只不过这是我们自定义的,叫Student。
创建实例的方法十分简单。即:
student = Student(括号内传入在__init__函数中定义的参数)
python是一门动态语言。创建好的实例可以自由地添加属性。在类中声明的read-only的属性,在实例中不能del。在实例中通过构造函数添加的或者在类外动态添加的属性可以del。
类中的read-only属性只能通过类属性的形式删除。
class Fridge(object): color = "yellow" width = 20 def __init__(self, height): self.height = height def storage(self): print "keep %s fresh" fridge = Fridge(100) fridge.name = "Haier" del fridge.color # AttributeError 报错 del fridge.height del fridge.name del Fridge.width
怎么给实例或类动态添加方法?先挖个坑,学习了再写。