python 中关于self到底有什么用续

一个程序帮助你理解类中的一些基本的概念

a = 1
def
say(): print('调用了全局方法(people外)') class Creative(): def say(self): print('来自Creative的say') def creative_say(self): self.say() class People(Creative):    a = 100 b = 123 def __init__(self): self.a = 10000 @classmethod def talk(cls): print('这里是people类方法')

def say():
print('来自不带参数的say')
def say(self): print('调用了People类里面的方法') @staticmethod def tool(): print('来自People类的工具包') def do(self): say() self.say() print('a = ', a) print('self.a = ', self.a) print('self.b = ', self.b) print('People.b = ', People.b) p = People() p.do() p.creative_say()
下面是答案
调用了全局方法(people外)
调用了People类里面的方法
a =  1
self.a =  10000
self.b =  123
People.b =  123
调用了People类里面的方法
View Code

实际上类中的变量还是很灵活的,还可以形参角度,实例化时给予不同的数据结构 --- 数,字符串,BOOL值,函数,类的实例化等

我想还是总结一下:

一 函数和方法还是有所不同的

1, 类中的函数, 称之为方法,主要的特点是:self的参数必备,是与特定的实例的绑定的函数,需要调用方法是,实例本身作为第一个参数自动传递给self,普通函数不具备这样的功能

2,作为普通还是,还是需要传递所有的参数,不能自动传参的。 

3, 以sort()函数,是需要要排序的对象指明,[列表].sort()类似于调用列表实例的方法,自动传递!

二 类中的所有函数和特征,都是给类和实例调用的数据和方法, 不能执行运行的,需要通过类和实例才能调用。如果有运行函数,则会在类外寻找,如果没有就会报错!!

三 类中 不带有self参数的函数, 这是给类调用的, 不是给实例,如果实例调用就会报错

四 如果在类中有同名的方法,则会以最后的方法执行, 包括带参数还是不带参数.

原文地址:https://www.cnblogs.com/vincent-sh/p/12796278.html