这篇文章主要为大家展示了“Python中如何实现类的定义与继承”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Python中如何实现类的定义与继承”这篇文章吧。
创新互联公司科技有限公司专业互联网基础服务商,为您提供达州托管服务器,高防服务器租用,成都IDC机房托管,成都主机托管等互联网服务。具体如下:
定义类:
class A: def __init__(self, name): self.name = name def say(self): print self.name def __del__(self): print "delete: %s" % self.name
1. python类的所有方法定义都必须至少含有一个参数,也就是self参数。在方法定义时作为第一个参数存在,self参数是类实例的引用。
2. __init__
方法相当于构造函数,在获取类实例的时候会执行。
3. __del__
方法相当于析构函数,会由系统自动调用(类似垃圾回收),也可以通过del对象主动调用。
4. 上例在__init__
方法里定义了一个对象的变量name,可以在类内其他地方通过self.name
引用。
获取类的实例并调用类方法:
a = A('Jim') #不用new a.say() #Jim A.say(a) #Jim
调用类的方法有两种方式:
1. 对象.方法名
,此种方式self参数不需要指定,对象引用作为实参自动传入。
2. 类名.方法名
,此种方式self参数需要指定为类实例的引用。
类变量和对象变量:
class A: pass a = A() print A.j #报错,因为A类中不存在类变量j A.i = 1 #在A类中添加类变量i,并赋值1 print A.i #打印1 print a.i #打印1,这里的a.i实际上取到的是类A的类变量i,非对象a的对象变量i(其尚不存在) a.j = 2 #在对象a中添加对象变量j,并赋值2 print A.j #报错,因为A类中不存在类变量j print a.j #打印2 a.i = 3 #在对象a中添加对象变量i,并赋值3 b = A() print A.i #打印1,A.i取到的是A类中的类变量i print a.i #打印3,a.i取到的是a对象中的对象变量i,取不到类A中的类变量i(因为重名优先获取对象变量) print b.i #打印1,b.i取到的是A类中的类变量i
总结:
1. 对象的变量称为对象的域;类的变量称为类的域(相当于类静态变量)。类的域和方法合称类的属性。(我们没用域,而用了变量这个称呼)。
2. 类和对象的变量可以在类定义后随意添加。
3. 如果我们用 对象.i
取用变量(取用而非赋值),会先试图取用对象变量i,若不存在则试图取用对象所属类中的类变量i,若还不存在则报错。
4. 可使用对象引用获取类变量值(在不存在重名的对象变量时),但不能用对象引用给类变量赋值(会创建同名对象变量)。
定义类变量:
在类内直接定义的变量是类变量,不属于某个特定对象,相当于静态变量,如:
class P: __pri = "private via" count = 1 print P.count #打印1 print P.__pri #报错,类P中没有名称为__pri的属性
1. 使用类变量通常用:类名.变量名
2. 类的属性默认是公有的;类定义中,变量名为双下划线开头的变量是私有的(依靠约定来保证)。
类的继承:
在类定义时,类名称后紧跟一个元组名,此类即为以元组的元素为父类的子类:
class SubClass(SuperClass): pass class SubClass(SuperClass1, SuperClass2): pass
1. 若类没有显式的定义__init__
方法,则python会自动生成一个__init__(self)
方法;且如果这个类有父类,此子类自动生成的__init__(self)
方法会依次调用父类的__init__(self)
方法,若父类中没有__init__(self)
这样的方法,执行就会报错。
2. 若显式定义__init__
方法,父类的__init__
方法不会自动调用,需要代码显式调用。这和java不同,java会自动在构造方法的第一句加入super()
语句。
以上是“Python中如何实现类的定义与继承”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!