在之前的博客中简单地说了关于类的继承的语法,今天在具体的说一下类的相关的知识。
先用一段代码温习一下之前学过的类的继承:
class Parent:
def hello(self):
print("正在调用父类的方法.....")
class Child(Parent):
# pass
def hello(self):
print("正在调用子类的方法.....")
p=Parent()
p.hello()
c=Child()
c.hello()
在类的继承中需要注意的几个问题:
(1)如果子类中定义与父类同名的方法或者属性则会自动覆盖父类对应的方法或者属性。
import random as r
class Fish:
def __init__(self):
self.x=r.randint(0,10)
self.y=r.randint(0,10)
def move(self):
self.x-=1
print("我的位置是:",self.x,self.y)
class Goldfish(Fish):
pass
class Carp(Fish):
pass
class Salmon(Fish):
pass
class Shark(Fish):
def __init__(self):
#调用未绑定的父类方法,传进去的是子类的实例化对象
#Fish.__init__(self)
#使用super()函数
super().__init__()
self.hungry=True
def eat(self):
if self.hungry:
print("吃货的梦想是天天有的吃")
self.hungry=False
else:
print("太撑了,吃不下了")
shark=Shark()
shark.move()
#这样写的话程序会报错,因为子类Shark重写了了
#__init__方法,这样就会覆盖父类的__init__方法
(2)Python还支持多重继承
class Base1:
def foo1(self):
print("我是foo1,我为Base1代言...")
class Base2:
def foo2(self):
print("我是foo2,我为Base2代言...")
class C(Base1,Base2):
pass
c=C()
c.foo1()
c.foo2()
(3)当几个类之间没有直接的继承关系时我们可以使用组合。
例如下面代码中的Turtle、Fish、Pool三个类,它们之间并没有明显的继承关系,但是使用组合却可以很方便的解决这几个类之间的问题。下面代码就解决了输出池塘中有多少只金鱼和乌龟的问题。主要解决办法就是将乌龟和金鱼类的实例化放进池塘的类中。
class Turtle:
def __init__(self,x):
self.num=x
class Fish:
def __init__(self,x):
self.num=x
class Pool:
def __init__(self,x,y):
#将类的实例化放到另一个类中
self.turtle=Turtle(x)
self.fish=Fish(y)
def print_num(self):
print("水池里总共有乌龟%d只,小鱼%d条!"%(self.turtle.num,self.fish.num))
pool=Pool(1,10)
pool.print_num()
最后补充一些关于类的内置函数:
#前面是子类,后面是基类
#issubclass(class,classinfo)
#判断一个类是否为另一个类的子类
#一个类被认为是自身的子类
class A:
pass
class B(A):
pass
print(issubclass(B,A))
#isinstance(object,classinfo)
#前面是一个实例化对象,后面是类
#检查实例对象是否属于这个类
b1=B();
print(isinstance(b1,B))
#hasattr(object,name)
#测试一个对象是否有特定的属性
class C:
def __init__(self,x=0):
self.x=x#一定要注意Python没有变量的定义
c1=C()
print(hasattr(c1,"x"))
#getattr(object,name[,default])
#返回对象指定的属性值,如果不存在,打印设置的默认值
print(getattr(c1,'x'))
print(getattr(c1,'y',"您访问的参数不存在"))
#setattr(object,name,value)
#设定属性的值,如果不存在,会自动新建
setattr(c1,"y","Yaoxiangxi")
print(getattr(c1,'y',"您访问的参数不存在"))
#delattr(object,name)
#删除属性
delattr(c1,'y')
#property(fget=None,fset=None,fdel=None,doc=None)
#通过属性设置属性
class C:
def __init__(self,size=10):
self.size=size
def getSize(self):
return self.size
def setSize(self,value):
self.size=value
def delSize(self):
del self.size #删除某个属性
#便于代码的修改
x=property(getSize,setSize,delSize)
c1=C()
print(c1.getSize())
print(c1.x)
c1.x=100
print(c1.x)
关于最后的property将在描述符的博客中做详细的解释。