Python中三个装饰器函数用法(property、staticmethod、classmethod )

一. property的用法,将一个函数伪装成属性

#第一种写法:
from math import pi
class Circle:
    def __init__(self,r):
        self.r=r
    def mj(self):
        return pi*self.r**2
    def zc(self):
        return 2*pi*self.r
c1=Circle(3)
print(c1.mj())

#第二种写法:用property 将一个函数伪装成为属性
class Circle:
    def __init__(self,r):
        self.r=r
    @property
    def mj(self):
        return pi*self.r**2
    @property
    def zc(self):
        return 2*pi*self.r
c1=Circle(3)
print(c1.mj)


# property 跟__私有属性的结合 如:苹果打折的问题
class Goods():
    def __init__(self,price,discount):
        self.__price=price
        self.discount=discount
    @property
    def price(self): #现有的价格
        return self.__price * self.discount
    @price.setter #设置一个新的属性即新的价格
    def price(self,newprice):
        self.__price=newprice
    @price.deleter #删除一个价格
    def price(self):
        del self.__price

apple=Goods(8,0.7)
print(apple.price)
apple.price=10
print(apple.price)
print(apple.__dict__)
del apple.price
print(apple.__dict__)

二.classmethod

类方法通过@classmethod装饰器实现,类方法和普通方法的区别是, 类方法只能访问类变量,不能访问实例变量

如果某一个类中的方法 并没有用到这个类的实例中的具体属性
只是用到了类中的静态变量 就使用类方法

class Dog(object):
    def __init__(self,name):
        self.name = name

    @classmethod
    def eat(self):
        print("%s is eating" % self.name)



d = Dog("ChenRonghua")
d.eat()

执行报错如下,说Dog没有name属性,因为name是个实例变量,类方法是不能访问实例变量的

此时可以定义一个类变量,也叫name,看下执行效果

class Dog(object):
    name = "我是类变量"
    def __init__(self,name):
        self.name = name
 
    @classmethod
    def eat(self):
        print("%s is eating" % self.name)
 
 
 
d = Dog("ChenRonghua")
d.eat()

这次没报错

# classmethod
class Person:
    Country='中国人'
    @classmethod  #把func变成了一个类方法
    def func(cls): #cls指向了类的内存空间
        print('当前角色的国家是%s' %cls.Country)
# alex=Person()
# alex.func()

Person.func()

三.staticmethod 静态方法不需要self这个参数了

通过@staticmethod装饰器即可把其装饰的方法变为一个静态方法,什么是静态方法呢?

其实不难理解,普通的方法,可以在实例化后直接调用,并且在方法里可以通过self.调用实例变量或类变量,但静态方法是不可以访问实例变量或类变量的,一个不能访问实例变量和类变量的方法,其实相当于跟类本身已经没什么关系了,它与类唯一的关联就是需要通过类名来调用这个方法

# staticmethod
## 如果 一个方法 既不会用到对象中的属性也不会用到类中的属性
# 就应该被定义为一个静态方法
# 小编创建了一个Python学习交流群:725638078

class Student:
    @staticmethod #不需要实例化一个学生可以直接调用login登录方法
    def login():
        name=input('name:')
        pwd=input('pwd:')
        if name =='hu' and pwd =='123':
            print('登录成功')

Student.login()

你可能感兴趣的:(python,开发语言,装饰器)