class CLanguage: pass #下面定义了一个实例方法 def info(self): print("正在调用实例方法") #下面定义了一个类方法 @classmethod def info2(cls): print("正在调用类方法") #下面定义个静态方法 @staticmethod def info3(): print("正在调用静态方法") #类可以动态添加以上 3 种方法,会影响所有实例对象 CLanguage.info = info CLanguage.info2 = info2 CLanguage.info3 = info3 clang = CLanguage() #如今,clang 具有以上 3 种方法 clang.info() clang.info2() clang.info3() #类实例对象只能动态添加实例方法,不会影响其它实例对象 clang1 = CLanguage() clang1.info = info #必须手动为 self 传值 clang1.info(clang1)程序输出结果为:
正在调用实例方法
正在调用类方法
正在调用静态方法
正在调用实例方法
class CLanguage: __slots__ = ('name','add','info')可以看到, CLanguage 类中指定了 __slots__ 属性,这意味着,该类的实例对象仅限于动态添加 name、add、info 这 3 个属性以及 name()、add() 和 info() 这 3 个方法。 比如,在 CLanguage 类的基础上,添加如下代码并运行:
def info(self,name): print("正在调用实例方法",self.name) clang = CLanguage() clang.name = "C语言中文网" #为 clang 对象动态添加 info 实例方法 clang.info = info clang.info(clang,"Python教程")程序运行结果为:
正在调用实例方法 C语言中文网
def info(self,name): print("正在调用实例方法",self.name) clang = CLanguage() clang.name = "C语言中文网" clang.say = info clang.say(clang,"Python教程")运行程序,显示如下信息:
Traceback (most recent call last):
File "D:\python3.6\1.py", line 9, in <module>
clang.say = info
AttributeError: 'CLanguage' object has no attribute 'say'
def info(self): print("正在调用实例方法") CLanguage.say = info clang = CLanguage() clang.say()程序运行结果为:
正在调用实例方法
class CLanguage: __slots__ = ('name','add','info') #Clanguage 的空子类 class CLangs(CLanguage): pass #定义的实例方法 def info(self): print("正在调用实例方法") clang = CLangs() #为子类对象动态添加 say() 方法 clang.say = info clang.say(clang)运行结果为:
正在调用实例方法
显然,__slots__ 属性只对当前所在的类起限制作用。
本文链接:http://task.lmcjl.com/news/9705.html