1、定义
__metaclass__=type
class Person:
def __init__(self,name,age):
self.name=name
self.age=age
def setName(self,name):
self.name=name
def getName(self):
return self.name
def setAge(self,age):
self.age=age
def getAge(self):
return self.age
p1=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=name
self.age=age
def setName(self,name):
self.name=name
def getName(self):
return self.name
def setAge(self,age):
self.age=age
def getAge(self):
return self.age
p1=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=name
self.__age=age
def setName(self,name):
self.__name=name
def getName(self):
return self.__name
def setAge(self,age):
self.__age=age
def getAge(self):
return self.__age
p1=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=name
self.__age=age
def setName(self,name):
self.__name=name
def getName(self):
return self.__name
def setAge(self,age):
self.__age=age
def getAge(self):
return self.__age
p1=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=name
self.__age=age
def setName(self,name):
self.__name=name
def getName(self):
return self.__name
def setAge(self,age):
self.__age=age
def getAge(self):
return self.__age
class ITer(Person):
def __init__(self,name,age,lan):
super(ITer,self).__init__(name,age)
self.lan=lan
def getLan(self):
return self.lan
def setLan(self,lan):
self.lan=lan
p2=ITer('Sun',22,'python')
print p2.getLan()
print p2.getName()版权声明:本文为博主原创文章,未经博主允许不得转载。
原文:http://blog.csdn.net/er_plough/article/details/47336137