2 Python 类,实例,静态方法

类,实例,静态方法

转载请标明出处(http://blog.csdn.net/lis_12/article/details/52693285)

类与实例

类名通常由大写字母开头.

实例变量

  • 类与实例相互关联着:类是对象的定义,而实例是真正的实物.它存放了类中所定义的对象的具体信息.
  • 类既可以很简单,也可以很复杂.最简单的情况下,类仅仅用作名称空间(namespace).这样就是把数据放到了变量中,对他们按照名称空间进行分组,使得他们处于同样的关系空间中(点属性标识).
  • 将实例与方法、变量严格绑定在了一起,没有实例的时候不能调用实例变量和方法.
  • 构造器是最早设立实例属性的地方,因为__init__()函数是实例创建后第一个被调用的函数.
'''这个类没有任何方法和属性,只被用作名称空间容器'''
class namespace(object):
    pass

a = namespace()
b = namespace()
print dir(a)
'''['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__'] 以上为object的属性和方法'''
a.x = 10
a.y = 11
print dir(a)
'''['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'x', 'y']'''
#多了x,y a.x,a.y为实例属性,并不是类属性
print b.x # error,因为上述的x为实例a的实例属性,是实例a的独有属性,与b无关.

实例方法

class Test(object):
    def __init__(self,a):
        self.n = a
    def fun(self,a):
        print a,self.n
t = Test(2)
t.fun(1)
''' self这个参数代表实例对象本身,当用实例调用方法的时候,解释器会自动传递给方法; Test的fun函数有两个参数,第一个参数self解释器自动传的,如果函数中的参数没有self参数,该函数不能调用实例属性; self类似于c++中的this '''

类属性

  • 类和实例读书名字空间.类是类属性的名字空间,实例则是实例属性的空间.
  • 访问属性时,首先会检测实例属性;如果未找到该属性则会在类属性中继续查找.
class Test(object):
    version = 1

 a =  Test()
 b = phonebook()
 print a.version,b.version  # 1 1

 a.version = 41             #相当于给a增加了一个叫version的实例属性,这样就访问不到Test.version了,a.version不再引用Test.version,此时a.version引用41
 print a.version,b.version  #41 1 

 print Test.version         #1
 ''' 实例属性覆盖了对类属性的引用,但是对类属性来说没有任何影响,仍然存在于类域中,还是可以通过类属性来访问 '''
 Test.version = 100         #只能通过这种方式修改类属性
 print a.version,b.version  #41 100

 del a.version              #删除实例属性,然后就能访问到类属性了.
 print a.version,b.version  # 100 100

注:类属性最好通过类属性来修改,而不要通过实例属性来修改,不然会出现意想不到的错误!!!!!

静态变量

静态属性是与他们所属的类对象绑定的,不依赖任何类实例.相当于c++中的static。

ps:在python里貌似把静态变量归属于类属性里面了.

class Test():
    self.a = 100 #error,因为不知道self是什么,并没有像参数一样传进来,实例属性最早是在__init__中实现
    var = 1  #静态变量,前面没有self

var = Test.var
print var
Test.var = 100
print Test.var

方法

绑定方法

存在一个实例可以调用此方法,大部分情况下,调用的都是绑定的方法,即实例方法.

非绑定方法

不用实例就可以调用的方法

如子类覆盖父类的构造方法

class A(B):
    def __init__(self):
        B.__init__(self)

静态方法

def Test(object):
    def static_fun():
        print 'static'
        static_fun = staticmethod(static_fun)
#上述写法太low了,装饰器闪亮登场--!(装饰器待讲,先知道有这个东西....)
def Test(object):
    @staticmethod
    def static_fun():
        print 'static'

类方法

def Test(object):
    def class_fun(cls):
        print 'class'
    class_fun = classmethod(class_fun)
''' cls作为参数代表着本类 '''
def Test(object):
    @classmethod
    def class_fun(cls):
        print 'class'

example code

class Test():
    def __init__(self):
        self.a = 100

    def fun(self):
        print 'self',self.a
        #static_fun() error
        Test.static_fun() #right
        #cls_fun() error
        Test.cls_fun()#right

    @staticmethod
    def static_fun():
        print 'static'
        #fun() error
        #cls_fun() error

    @classmethod
    def cls_fun(cls):
        print 'cls'
        #fun() error
        #static_fun() error

    def test(self,cls):
        self.fun()
        cls.static_fun()
        cls.cls_fun()

if __name__ == '__main__':#主程序
    a = Test()
    a.fun()
    a.static_fun()
    a.cls_fun()
    a.test(Test)
''' 上述错误大部分是因为没有传入参数self(实例),cls(类) 静态方法需要由类.fun或者实例变量.fun来调用 '''

感觉静态方法和类方法很相似啊- -只不过一个需要传递参数,一个不需要啊- –

类方法,静态方法区别

补充:找到了静态方法和类方法的区别了,直接见代码吧…

#!/usr/bin/python
# -*- coding: utf-8 -*-

class A(object):
    def fun(self):
        print "This is A"

    @staticmethod
    def static_f():
        return A()

    @classmethod
    def class_f(cls):
        return cls()

class B(A):
    def fun(self):
        print "This is B"


if __name__ == '__main__':
    a = B.static_f()
    b = B.class_f()
    a.fun()  #This is A
    b.fun()  #This is B
    raw_input()

当使用类方法和静态方法创建对象时,类方法更灵活一些…另外静态方法和类方法与实例方法存储在同一命名空间,这也是与其他面向对象语言(如ruby)的区别之一,这些语言都是将类方法与实例方法严格分开的.

    原文作者:忧桑的小兔子
    原文地址: https://blog.csdn.net/lis_12/article/details/52693285
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞