#!/usr/bin/python # -*-coding:utf-8-*- from types import MethodType """ 文件名 class2.py MethodType 测试 """ # 首先看第一种方式 #创建一个方法 def set_age(self, arg): self.age = arg #创建一个类 class Student(object): pass #------以上为公共部分 s_one = Student() #给student 创建一个方法 但这里不是在class中创建而是创建了一个链接把外部的set_age 方法用链接指到Student内
# 原:s_one.set_age = MethodType(set_age,s_one,Student)
s_one.set_age = MethodType(set_age,s_one)
s_one.set_age(
32)
#
调用实例方法
print
s_one.age
#
》》》》结果 32
s_two =
Student()
s_two.set_age(
100)
#
这里来验证下是在类内有方法还是类外有方法。
print
s_two.age
#
》》》》结果Traceback (most recent call last):
#
》》》》 File "class2.py", line 22, in <module>
#
》》》》 s_two.set_age(100)
#这里来验证下是在类内有方法还是类外有方法。
#
》》》》 AttributeError: 'Student' object has no attribute 'set_age'
看另一种
#直接用类来创建一个方法 不过此时还是用链接的方式在类外的内存中创建 Student.set_age = MethodType(set_age,Student) # 原:此时在创建实例的时候外部方法 set_age 也会复制 这些实例和Student类都指向同一个set_age方法 此时在创建实例的时候外部方法 set_age 也会复制 这些实例和Student类都指向同一个set_age方法(就像是在定义Student这个类的时候定义了set_agee这个方法,但也不完全是。因为变量age是个类变量,无论哪个Student类的实例修改age,其他实例都可以实时获取最新的age,大概是这意思。加一点:此时的age就像是c++里面的类的static变量,任何一个该类(Student)的实例(new1,new2,……)都可以修改它(age)) new1 = Student() new2 = Student() new1.set_age(99) new2.set_age(98) #第二个会覆盖第一个 print (new1.age,new2.age) #看结果 2个都是98 #》》》》(98, 98)