python装饰器之staticmethod,classmethod,property

文章出处:http://www.python123.com/thread-50-1-1.html。部分内容加以补充。


  许久之前,一直不知道staticmethod,classmethod,property能做什么用处,不过说实话,这三个装饰器的用处也不是很大~

但是呢,偶尔还是会接触到相关的,所以还是弄清楚比较的好。


   1. 先说说staticmethod吧

  class Rabbit:
      @staticmethod
      def mystatic(wParam,lParam):
            print 'this is  a static method'
     
  这里 mystatic 静态方法,和 c++里面的类静态方法基本一样。

It can be called either on the class (such as C.f()) or on an instance (such as C().f()). The instance is ignored except for its class.Static methods in Python are similar to those found in Java or C++.


===========================================

另外一种非静态方法:

class pin:
  #@staticmethod

  def pi(self): 
    return 'ok'

va=pin()

print va.pi()   #如果在静态方法中执行该句,则需要把pi(self)中的self去掉

#print pin.pi()  #非静态方法中,必须创建类的实例,通过实例调用方法。如果把此注释去掉,则会报错

===========================================


2.classmethod
   请先看下例子输出:
class Rabbit(object):
    def __init__(self,name):
        self._name = name
    @classmethod
    def newClass(cls):
        return 'abc',cls,Rabbit('')

=========================

或者:

r=Rabbit('am')
print r.newClass()

=========================
>>> Rabbit.newClass()
('abc', <class '__main__.Rabbit'>, <__main__.Rabbit object at 0x0259F130>)

仔细看下也就明白了,classmethod和普通的函数,就是把传入的self换成了cls对象,注意非任何实例。


3.property

细心的读者可能发现上面两个例子的类构造不一样,是的。porperty修饰器是针对新的对象方式的.
class Rabbit(object):
    def __init__(self,name):
        self._name = name
    @classmethod
    def newClass(cls):
        return 'abc',cls,Rabbit('')
    @property
    def name(self):
        return self._name
>>> ================================ RESTART ================================
>>>
>>> r = Rabbit('abc')
>>> r
<__main__.Rabbit object at 0x0258F130>
>>> r.name
'abc'
>>> r.name = '1'

Traceback (most recent call last):
  File "<pyshell#25>", line 1, in <module>
    r.name = '1'
AttributeError: can't set attribute
说白了,就是给函数设置只读属性。
这里定义的属性是一个只读属性,如果需要可写,则需要再定义一个setter:
class Rabbit(object):
    def __init__(self,name):
        self._name = name
    @classmethod
    def newClass(cls):
        return 'abc',cls,Rabbit('')
    @property
    def name(self):
        return self._name
    @name.setter
    def name(self,newname):
        self._name= newname

另外说下:如果类定义的时候是 class Rabbit: ...这样的话,这个@property是米有只读限制的。建议大家都用新的类定义风格吧~


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
@staticmethodPython中的一个装饰器,它用于声明一个静态方法。静态方法可以在不创建类的实例对象的情况下直接调用,通过类名.方法名的方式进行调用,而不需要传入self参数。\[1\] 在给定的代码示例中,my_class类中的func2方法被@staticmethod装饰器修饰,因此可以直接通过my_class.func2()的方式进行调用。而func1方法没有被修饰,所以需要通过创建类的实例对象来调用。\[1\] 在另一个示例中,func1方法被@classmethod装饰器修饰,这意味着它可以通过类名.方法名的方式进行调用,而不需要传入cls参数。而func2方法没有被修饰,所以需要通过创建类的实例对象来调用。\[2\] 如果一个方法没有被任何装饰器修饰,那么它就是一个普通的实例方法,需要通过创建类的实例对象来调用,并且需要传入self参数。\[3\] 总结来说,@staticmethod装饰器用于声明静态方法,可以在不创建类的实例对象的情况下直接调用。而@classmethod装饰器用于声明类方法,可以通过类名.方法名的方式进行调用。普通的实例方法需要通过创建类的实例对象来调用,并且需要传入self参数。 #### 引用[.reference_title] - *1* *2* *3* [python中的内置装饰器@classmethod,@staticmethod和@property](https://blog.csdn.net/qq_44690947/article/details/127482212)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值