版权声明:转载请注明作者(独孤尚良dugushangliang)出处: https://blog.csdn.net/dugushangliang/article/details/90177203
直接上代码,如下。
class Father(object):
def __init__(self, names):
self.names=names
print ( "name: %s" %( self.names) )
def getName(self):
return 'Father ' + self.names
class Son(Father):
def __init__(self, name):
#super().__init__(name)
print ( "hi" )
self.name = name
def getNames(self):
return 'Son '+self.name
if __name__=='__main__':
son=Son('runoob')
print ( son.getName() )
上面的代码会报错。
这是因为两个类都没names这个变量,但子类的构造函数,即初始化函数,即实例化函数__init__中有新建一个成员变量name,所以使用name没问题而names有问题。
如果Father类的getName函数中反回的是self.name而不是self.names,则没有问题。这说明父类的函数被继承到了子类,这个函数可以访问子类的变量。也说明子类实例化的时候没有调用父类的实例化函数__init__。
但下面的代码可以正常执行。
class Father(object):
names='中国'
def __init__(self, names):
self.names=names
print ( "name: %s" %( self.names) )
def getName(self):
return 'Father ' + self.names
class Son(Father):
def __init__(self, name):
#super().__init__(name)
print ( "hi" )
self.name = name
def getNames(self):
return 'Son '+self.name
if __name__=='__main__':
son=Son('runoob')
print ( son.getName() )
这是因为,虽然没有执行父类的构造函数__init__,但有这个names变量,所以可以正常执行。
独孤尚良dugushangliang——著