深圳湾 2018-01-14
定义类与实例化<br /> #定义父类 用于单位转换<br /> class ScaleConverter: <br /> def __init__(self,unit_from,unit_to,factor): #第一个参数必须是self <br /> self.unit_from=unit_from <br /> self.unit_to=unit_to <br /> self.factor=factor <br /> def description(self): #函数必须传入self,self用于区分是哪个对象调用该方法 <br /> return 'Convert '+self.unit_from+' to '+self.unit_to <br /> def convert(self,value): <br /> return value*self.factor <br /><br /><br /> c1=ScaleConverter('inches','mm',25) #实例化类 <br /> print(c1.description()) <br /> print(str(c1.convert(2))+c1.unit_to) <br /><br /><br />属性查找与绑定方法<br /> 参考 https://www.cnblogs.com/seirios1993/p/6624157.html 博客<br /><br /> 1. 类绑定属性<br /> 类绑定属性可以直接在class中定义属性,这种属性是类属。<br /> class Student(object):<br /> name = 'Student'<br /> 这个属性虽然归类所有,但类的所有实例都可以访问到。<br /><br /> class Student(object):<br /> name = 'Student'<br /> s = Student() # 创建实例s<br /> print(s.name) # 打印name属性,因为实例并没有name属性,所以会继续查找class的name属性<br /> print(Student.name) # 打印类的name属性<br /> Student<br /> Student<br /><br /> 此时如果修改s.name的值,会有如下结果:<br /> s.name = 'xiaoming' # 给实例绑定name属性<br /> print(s.name) # 由于实例属性优先级比类属性高,因此,它会屏蔽掉类的name属性<br /> print(Student.name) # 但是类属性并未消失,用Student.name仍然可以访问<br /> xiaoming<br /> Student<br /><br /> 接下来删除s.name属性:<br /> del s.name # 如果删除实例的name属性<br /> print(s.name) # 再次调用s.name,由于实例的name属性没有找到,类的name属性就显示出来了<br /> Student<br /> 由此可见相同名称的实例属性将覆盖类属性,删除实例属性后,实例将向上访问到类属性。<br /><br /> 2.实例绑定属性<br /> 实例绑定属性的方法有两种,一是通过类的self变量,二是直接给实例赋值。<br /> class Student(object):<br /> def __init__(self, name):<br /> self.name = name<br /> s = Student('Bob') #方法一 通过类的self变量绑定属性<br /> s.score = 90 #方法二 直接赋值<br /><br /> 3.类绑定方法<br /> 类绑定方法分两种,第一种形如类绑定属性,例程如下:<br /> class Student(object):<br /> pass<br /><br /> a = Student()#创建实例<br /><br /> def set_score(self,score):<br /> self.score = score<br /><br /> Student.set_score=set_score#类绑定方法<br /> a.set_score(99)#调用方法<br /> print(a.score)<br /> 99#输出<br /><br /> 第二种是使用MethodType给类绑定方法:<br /> Class Student(object):<br /> pass<br /> a=Student()#创建实例<br /><br /> def set_score(self,score):<br /> self.score=score<br /><br /> from types import MethodType<br /> Student.set_score = MethodType(set_score, Student)<br /><br /> a.set_score(99)#调用方法<br /> a.score<br /> 99#输出<br /><br /> 这种方法有一个需要注意的地方,如果继续创建一个实例b:<br /> b=Student()<br /> b.set_score(60)<br /> b.score<br /> a.score<br /> 60<br /> 60<br /> 会发现a的属性score值也变成60。这里个人的理解是这里的score并不是同上一种方法一样直接绑定在类,而是类似于像列表一样的共享<br /> 引用的关系,即实例a和b都引用这个score作为自己的属性,而当其被修改时,所有引用它的实例的对应属性都将一同发生变化。<br /><br /> 4.实例绑定方法<br /> 第一种通过给类绑定方法,可以使实例调用,如上所示。<br /> 第二种是使用MethodType给单个实例绑定方法。<br /> Class Student(object):<br /> pass<br /> a=Student()#创建实例<br /><br /> def set_score(self,score):<br /> self.score=score<br /><br /> from types import MethodType<br /> a.set_score = MethodType(set_score, a)<br /><br /> a.set_score(99)#调用方法<br /> a.score<br /> 99#输出<br /> 注意这种方式只对实例a起作用,如果需要类Studet的所有实例均可调用,那么直接给类Student绑定方法即可。
是一道经常出现在前端面试时的问题。如果只是简单的了解new关键字是实例化构造函数获取对象,是万万不能够的。更深入的层级发生了什么呢?同时面试官想从这道题里面考察什么呢?下面胡哥为各位小伙伴一一来解密。