亲宝软件园·资讯

展开

一文带你弄懂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时,里面的一种定义方式。里面是包含两个参数 nameage。在实例的时候,必须要传入这两个参数的值进去。

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

以第一种的区别,这种定义方式时,没有形参的。但是它已经指定nameage都是 None, 相当于这两个参数已经赋值,不过是None

这种形式是可以直接实例对象,然后再给对象里的属性赋值:

stu = Student() # 正常实例
"""查看stu对象的属性是什么状态"""
print(stu.__dict__) # 打印出:{'name': None, 'age': None}

然后再来重新给对象的属性赋值:

stu.name = '陈冠希'
stu.age = 16

以上就是__init__方法定义的一些区别。

那么为什么在class中 要定义__init__方法呢?因为他是一个初始化方法,没有初始化的话,实例后的对象,用__dict__方法查看对象里面的属性将是空的。

总结

加载全部内容

相关教程
猜你喜欢
用户评论