一文带你弄懂Python3中的def __init__
Jiabing Yu 人气:0前言
在学习python-100-days时,在面向对象编程基础的那一块,封装一个class时,突然出现def __init__
的方法,刚开始时,对他的理解很模糊,为什么定义一个类需要用到def __init__
。
于是翻找了一些资料,大概就是两种定义方式如下:
第一种定义方式如下:
class Student(object): # __init__是一个特殊方法用于在创建对象时进行初始化操作 # 通过这个方法我们可以为学生对象绑定name和age两个属性 def __init__(self, name, age): self.name = name self.age = age
上面这一种,是在学习python-100-days时,里面的一种定义方式。里面是包含两个参数 name
和 age
。在实例的时候,必须要传入这两个参数的值进去。
stu = Student() # 报错
如果上面直接实例它的话就会报错:TypeError missing 2 required positional arguments: 'name' and 'age'
正常情况下,我们应该传入参数:
stu = Student('大冰', 19) # 正常实例
然后我们可以利用__dict__
方法查看对象的属性。
print(stu.__dict__) # 打印出: {'name': '大冰', 'age': 19}
或者我们可以直接给__init__
方法设置一个默认参数,然后直接实例就不会报错了。
def __init__(self, name = '周星星', age = 12): self.name = name self.age = age stu = Student() # 不会报错,正常实例
第二种定义方式如下:
class Student(object): def __init__(self): self.name = None self.age = None
以第一种的区别,这种定义方式时,没有形参的。但是它已经指定name
和 age
都是 None
, 相当于这两个参数已经赋值,不过是None
。
这种形式是可以直接实例对象,然后再给对象里的属性赋值:
stu = Student() # 正常实例 """查看stu对象的属性是什么状态""" print(stu.__dict__) # 打印出:{'name': None, 'age': None}
然后再来重新给对象的属性赋值:
stu.name = '陈冠希' stu.age = 16
以上就是__init__
方法定义的一些区别。
那么为什么在class中 要定义__init__
方法呢?因为他是一个初始化方法,没有初始化的话,实例后的对象,用__dict__
方法查看对象里面的属性将是空的。
总结
加载全部内容