[python 笔记4]类(面向对象?)

来源:互联网 发布:佳能ip2880清零软件 编辑:程序博客网 时间:2024/05/19 04:28

  1、定义

   

__metaclass__=typeclass Person:def __init__(self,name,age):self.name=nameself.age=agedef setName(self,name):self.name=namedef getName(self):return self.namedef setAge(self,age):self.age=agedef getAge(self):return self.agep1=Person('C++','22')print p1.getName()p1.setName('Python')print p1.getName()print p1.name

__init__()为构造函数

其中__metaclass__=type确定使用新式类,python3.0以后就不用考虑新式类的问题,类的定义:

class Person(object):def __init__(self,name,age):self.name=nameself.age=agedef setName(self,name):self.name=namedef getName(self):return self.namedef setAge(self,age):self.age=agedef getAge(self):return self.agep1=Person('C++','22')print p1.getName()p1.setName('Python')print p1.getName()print p1.name

显然在类的定义中每一个函数参数列表的第一个都应该是self,self也就是对象本身,而self也是区分方法和对象函数的标志。

2、访问权限

通过上面的案例,可以发现对象的属性也是可以在外部进行访问的。

PS:熟悉c++的同学都知道,将对象的属性暴露在外面是非常危险的。

python 中并没有private关键字,而是使用双下划线”__”来完成属性的私有化,当然不只是属性,类中的方法也是使用同样的方法

class Person(object):def __init__(self,name,age):self.__name=nameself.__age=agedef setName(self,name):self.__name=namedef getName(self):return self.__namedef setAge(self,age):self.__age=agedef getAge(self):return self.__agep1=Person('C++','22')print p1.getName()p1.setName('Python')print p1.getName()print p1.__name

我们可以发现使用类中的方法可以继续访问对象的属性,在类外访问是失败的。

但是python中并没有什么特殊机制,而是将有双下划线的属性前面加上单下划线和类名,

例如:__name->_Person__name

class Person(object):def __init__(self,name,age):self.__name=nameself.__age=agedef setName(self,name):self.__name=namedef getName(self):return self.__namedef setAge(self,age):self.__age=agedef getAge(self):return self.__agep1=Person('C++','22')print p1.getName()p1.setName('Python')print p1.getName()print p1._Person__name


如果这样还是可以继续访问的。

3、继承

  继承不多介绍,就像上面的例子,在类名后面的括号内的类都是该类的父类,当有多个类为父类时,使用’,’间隔。子类继承父类,构造函数使用super(函数,构造父类继承来的属性方法等。

class Person(object):def __init__(self,name,age):self.__name=nameself.__age=agedef setName(self,name):self.__name=namedef getName(self):return self.__namedef setAge(self,age):self.__age=agedef getAge(self):return self.__ageclass ITer(Person):def __init__(self,name,age,lan):super(ITer,self).__init__(name,age)self.lan=landef getLan(self):return self.landef setLan(self,lan):self.lan=lanp2=ITer('Sun',22,'python')print p2.getLan()print p2.getName()



0 0
原创粉丝点击