Python: 关于类初始化使用的一点细节

先上代码

>>> class nn:
	def __init__(self,ss,kk):
		self.ss=ss
		self.kk=kk

>>> class kn(nn):
	def __init__(self,qq=1,ww=2):
		ss = qq * 15
		kk = ww *10
		super(kn, self).__init__(ss,kk)

>>> c = kn()
>>> c.ss
15
>>> c = kn(2,3)
>>> c.qq                                       
Traceback (most recent call last):                  ###可以看到这里只有ss,kk属
  File "", line 1, in           ###性,而初始化函数中的qq没有
    c.qq
AttributeError: 'kn' object has no attribute 'qq'
>>> c.ss
30
>>> a = nn(45,56)
>>> a.ss
45
>>> kn.qq                                          ##这里同样可以看见类kn直接
Traceback (most recent call last):                 ##调用qq
  File "", line 1, in 
    kn.qq
AttributeError: type object 'kn' has no attribute 'qq'

这里我们可以做一个判断,因为在kn定义中,没有self.qq所以这个参数是无法调用的,而在使用了super()函数后,相当于调用了kn父类nn的__init__()函数,因此ss是有self定义的,即可以被调用的,没有self定义的是内部类参数。

>>> class nn:
	def __init__(self,ss,kk):
		self.ss=ss
		self.kk=kk

		
>>> class kn(nn):
	def __init__(self,qq=1,ww=2):
		v = qq * 15
		h = ww *10
		super(kn, self).__init__(v,h)    #这里我把ss换成了v

		
>>> a = kn(2,3)
>>> a.ss
30
>>> a.v
Traceback (most recent call last):
  File "", line 1, in 
    a.v
AttributeError: 'kn' object has no attribute 'v'

同样可以看到,把ss换成v后,仍然只是可以调用ss,说明了我们super().__init__()中的从参数其实是传递给父类__init__()函数的。

你可能感兴趣的:(python)