Python中self用法总结
Python编写类的时候,每个函数参数第一个参数都是self,一开始认为其作用相当于java中的this,表示当前类的对象,可以调用当前类中的属性和方法。在经过编程实践并加上自己浅薄的理解后,将self用法总结为以下几点:1.在class函数中,需要访问当前的实例中的变量和函数。➡️而在class中需要访问实例的变量和调用实例的函数,需要对应实例对象本身。➡️在Python类中规定,函数的第一个参
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 中存储的是实例变量和实例函数的属性(注意并没有存储类里的方法)
浅薄观点欢迎指正。
更多推荐
所有评论(0)