1.类的定义 定义是用过class关键字 class Student(object): pass class 后面紧接着是类名,即Student,类名一般是大写开头的单词, 紧接着是(object),表示该类是从哪一个类继承下来的。若是没有合适 的继承类,就使用object类,这个是全部类最终都会继承的类。 定义好了Student类,就能够根据Student类建立出Student的实例, 建立实例是经过类名+()实现的 res = Student() print(res)#<__main__.Student object at 0x1035d35c0> print(Student)#<class '__main__.Student'> 能够看到,res指向的是一个Student实例,而Student本省则是一个类。 能够自由的给实例变量绑定属性,eg. 给res绑定一个name属性 res.name = 'Jake' print(res.name)#Jake 因为类能够起到模板的做用,所以,能够在建立实例的时候,把一些咱们 认为必须绑定的属性强制填写进去,经过定义一个特殊的__init__方法 在建立实例的时候,把name,age,sex等属性绑定上去。 def __init__(self, name, age, sex): self.name = name self.age = age self.sex =sex 注:__init__是双下划线 注意: __init__方法第一个参数永远是,self。表示建立的实例自己, 所以,在__init__方法内部,就能够把各类属性绑定到self, 所以,self就指向建立的实例自己。 有了__init__方法,在建立实例的时候,就不能传入空的参数了 必须传入与__init__方法匹配的参数,但self不须要传,Python 解释器本身会把实例变量传进去。 res = Student('Jake', 60, '男') print(res.age)#60 和普通方法相比,在类中定义的函数只有一点不一样,就是第一个参数永远 都是self,而且调用时,不用传递参数。除此以外,与类的方法与普通方 法没有什么区别。 总结: __dict__ : 可查询类和对象中内容,并以字典形式返回。 1.类名+() ---->实例化一个对象 2.这个时候会自动执行__init__方法,而且将对象传给__init__的self参数 3.给对象封装相应的属性。 2.数据封装 面向对象编程的一个重要的特色就是数据封装。 在上面的Student类中,每一个实例都拥有各自的name,age,sex这些数据。 既然Student实例自己就拥有这些数据,要访问这些数据,就没有必要从 外面的函数去访问,能够直接在Student类的内部定义访问数据的函数, 这样,就把“数据”给封装起来了。这些封装数据的函数是和Student类本 身是关联起来的,咱们称之为类的方法: class Student(object): def __init__(self, name, age, sex): self.name = name self.age = age self.sex =sex def print_message(self): print('%s:%s:%s' % (self.name, self.age, self.sex)) res = Student('Jake', 60, '男') res.print_message()#Jake:60:男 这样一来,咱们从外部看Student类,就只须要知道,建立实例须要给出name,age,sex 而如何打印,都是在Student类的内部定义的,这些数据和逻辑被“封装”起来了,调用很 容易,但却不用知道内部实现的细节。封装的另外一个好处就是,能够给Student类增长新 的方法。 总结: 1.类是建立实例的模板,而实例则是一个一个具体的对象,各个实例拥有的数据都是 互相独立的,互不影响。 2.方法就是与实例绑定的函数,和普通函数不一样,方法能够直接返回实例的数据。 3.Python容许对实例变量绑定任何数据,也就是说,对于两个实例变量,虽然他们 都是同一类的不一样实例,但拥有的变量名称均可能不一样。