一篇带你搞懂Python3 中的 def __init__
·
在学习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__
方法查看对象里面的属性将是空的。
更多推荐
已为社区贡献4条内容
所有评论(0)