Python编写类的时候,每个函数参数第一个参数都是self,一开始认为其作用相当于java中的this,表示当前类的对象,可以调用当前类中的属性和方法。

在经过编程实践并加上自己浅薄的理解后,将self用法总结为以下几点:

1.

在class函数中,需要访问当前的实例中的变量和函数。

➡️而在class中需要访问实例的变量和调用实例的函数,需要对应实例对象本身。

➡️在Python类中规定,函数的第一个参数是实例对象本身,于是约定俗成写为self。

2.给实例变量绑定属性(需要借def__init__(self) 函数)

直接上代码

class Person(object):  

pass

student = Person()

# print(student)

# print(Person)

student.name = "Gavin"   # 为实例变量 student 绑定 name 属性  类似于 赋值 操作

student.score = 100    # 为 其绑定 score 属性

print(student.name)p

rint(student.score)

这样的方法虽然可以为事例对象绑定属性但是不够方便,于是调用def __init__(self) 函数

(修改后的代码如下)

class Person(object):  

def __init__(self,name,score):    

self.name = name    

self.score = score    

student = Person('Gavin',100)  # 传入 __init__ 方法中需要的参数

print(student.name)

print(student.score)

3.在类中定义多个函数相互调用

在类中函数相互调用要加 self ,如上例中c = self.add()+self.square(), 不加 self ,会报错: 函数未定义。

class Person(object):  

def __init__(self,x,y):    

self.x = x    

self.y = y      

def add(self):    

sum = self.x + self.y    

return sum    

student = Person(3,4)

print(student.add())

 

最后,简单来说self可以把 class 中 定义的 变量和函数 变成 实例变量和实例函数,作为类 class 的成员,使得成员间能互相调用,而不需要从外部调用 数据(变量)和 方法(函数),以实现数据的封装,self 中存储的是实例变量和实例函数的属性(注意并没有存储类里的方法)

浅薄观点欢迎指正。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐