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)的区别之一,这些语言都是将类方法与实例方法严格分开的.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中的方法静态方法是两种特殊型的方法,它们与普通实例方法不同。我可以为你解释一下它们的区别和用法。 1. 方法(class method): - 方法是绑定到而不是实例方法。这意味着无论通过还是实例调用方法,它们都将访问和操作级别的属性。 - 方法使用装饰器`@classmethod`来标识,并且第一个参数通常被命名为`cls`,表示本身。 - 方法可以通过调用,也可以通过实例调用。当通过实例调用时,实际上会自动将实例转换为并传递给第一个参数`cls`。 2. 静态方法(static method): - 静态方法实例都无关,它们与实例的任何属性方法都没有直接的关系。 - 静态方法使用装饰器`@staticmethod`来标识,它们没有隐含的第一个参数。 - 静态方法可以通过直接调用,也可以通过实例调用。与方法不同,静态方法无法访问属性或调用其他方法。 下面是一个示例代码来说明它们的使用: ```python class MyClass: class_variable = "Hello, world!" @classmethod def class_method(cls): print("This is a class method") print("Class variable:", cls.class_variable) @staticmethod def static_method(): print("This is a static method") # 通过调用方法静态方法 MyClass.class_method() MyClass.static_method() # 通过实例调用方法静态方法 my_instance = MyClass() my_instance.class_method() my_instance.static_method() ``` 输出结果为: ``` This is a class method Class variable: Hello, world! This is a static method This is a class method Class variable: Hello, world! This is a static method ``` 希望这能回答你的问题!如果你还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值