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