python面对对象编程中会用到的装饰器

时间:2021-07-04 03:56:10

1、property

  用途:用来将对像的某个方法伪装成属性来提高代码的统一性。

class Goods:                #商品类
discount = 0.8            #商品折扣
def __init__(self,name,price):
self.name = name
self.price = price
def discountprice(self):      #定义goodsprice方法,返回折扣后价格
return self.price*self.discount
ipad = Goods('ipad',2299)    #实例化商品
print(ipad.name)
print(ipad.discountprice())  #打印商品的的折扣价格
      

  实时上商品的折扣价格应该跟商品的名字一样更像一个对象的属性应该是按照:对象.属性去访问而不是对象.方法()访问,因为抵扣价格更像是商品的属性。而property就可以将方法伪装成对象的属性:

class Goods:
discount = 0.8
def __init__(self,name,price):
self.name = name
self.price = price
@property    #在要装饰的方法前面加上@property,注意装饰的方法是除了self不能接受参数的
def discountprice(self):
return self.price*self.discount ipad = Goods('ipad',2299) print(ipad.name) print(ipad.discountprice)  #可以直接用访问属性的方法得到折扣价。
                 #这样我们就实现了对象访问的一致性。

  既然伪装成了一个属性,那么属性不仅可以访问应该还可以修改和删除,但是你发现你如果调用ipad.discountprice=1000,会执行错误,因为他本身还是个函数,只是被装饰器伪装了所以这里引入property的另外两个方法setter和deleter:      

class Goods:
discount = 0.8
def __init__(self,name,price):
self.name = name
self.price = price
@property
def discountprice(self):
return self.price*self.discount
@discountprice.setter      #装饰函数发送修改的值,必须有一个参数
def discountprice(self,new):
self.price = new
@discountprice.deleter
def discountprice(self):    #装饰函数删除属性
del self.price ipad = Goods('ipad',2299)
print(ipad.price) #
print(ipad.discountprice) #1839.2
ipad.discountprice = 3000    #执行被@discountprice.setter装饰的函数new接受3000
print(ipad.discountprice) # del ipad.discountprice    #删除属性 执行被@discountprice.deleter装饰的函数
print(ipad.discountprice) #报错没有discountprice

#以上就完全将discounsprice伪装成了属性,可以按照属性的查删改去调用discountprice,注意被property、setter、deleter装饰的函数一定要同名

# 一个方法被伪装成属性之后
# 应该可以执行一个属性的增删改查操作
# 那么增加和修改 就对应这被setter装饰的方法 :这个方法又一个必传的参数new,表示赋值的时候等号后面的值
# 删除一个属性 对应着 被deleter装饰的方法,这个方法并不能在执行的时候真的删除这个属性,而是你在代码中执行什么就有什么效果


#classmethod
# 在类中定义一个类方法 、是一个装饰器
# 什么时候用?
# 如果你的整个方法中都没有用到对象命名空间中的名字,且你用到了类的命名空间中的名字(普通方法和property方法除外)
# 类方法的默认参数 : cls 值得是调用这个方法的类
# 类方法的调用方式 : 通过类名调用,本质是方法

 

2、classmethod

  故名思议,类方法装饰器,当执行的方法操作的只有类的静态属性时,这个方法应该是用类本身去调用而不是实例的对象,还是上面的例子我要你用去定义个方法更改类的disount的值你会写出下面的代码

class Goods:
__discount = 0.8 # 静态属性
def __init__(self,price):
self.__price = price # 对象属性
self.name = 'apple' def price(self): return self.__price * Goods.__discount def change_discount(self,new): #方法在对象调用时,函数内部并没有引用对象任何属性
Goods.__discount = new
ipad = Goods('ipad',2000)
ipad.chang_discount(0.7)    #这样你虽然实现了更改了类的静态属性,但这在编程上是不规范的:对象通过方法修改类属性,在方法内部没有引用任何对象的属性,
                  #那么把对象调用就多余了,还有类的属性应该由类本身去修改 #修改如下:
class Goods:
__discount = 0.8 # 静态属性
def __init__(self,price):
self.__price = price # 对象属性
self.name = 'apple' def price(self): return self.__price * Goods.__discount
@classmethod
def change_discount(clf,new): # 类方法,这样这里的clf就如同对象调用方法自动将对象传入self一样会自动将类自己传入
clf.__discount = new
Goods.change_discount(0.7)  #这样就是类自己调用类方法修改自己的属性,而且只需要输入new的参数即可,crf会自动接收类本身

3、staticmethod

  静态方法,就是通常我们定义的函数,内部既不会引用对象方法属性也不会引用类属性和方法,但是需要你将他放在类里面,这样只是为了纯面向对象编程,外部无函数:

 class Foo:     @classmethod     def class_method(cls):pass     @staticmethod     def static_method():pass
Foo.static()      #通过类调用函数,传参和函数还是一致

# staticmethod
# 将一个普通的函数放到类中来就给这个函数加上一个@staticmethod装饰器
# 这个函数就不需要传默认的参数:self,cls
# 静态方法的调用方式 : 通过类名调用,本质还是函数

 

python面对对象编程中会用到的装饰器的更多相关文章

  1. python面对对象编程----2:__init__

    面对对象编程估计我们最早接触到的就是__init__了,也就是实例的初始化处理过程: 1:来看看最基础的__init__ class Card(object): #抽象类Card,并不用于实例化 de ...

  2. python面对对象编程------4:类基本的特殊方法__str__,__repr__,__hash__,__new__,__bool__,6大比较方法

    一:string相关:__str__(),__repr__(),__format__() str方法更面向人类阅读,print()使用的就是str repr方法更面对python,目标是希望生成一个放 ...

  3. python面对对象编程----------7:callable(类调用)与context(上下文)

    一:callables callables使类实例能够像函数一样被调用 如果类需要一个函数型接口这时用callable,最好继承自abc.Callable,这样有些检查机制并且一看就知道此类的目的是c ...

  4. Learning Python 012 函数式编程 2 返回函数 匿名函数 装饰器 偏函数

    Python 函数式编程 2 返回函数 返回函数的意思就是:函数作为返回值.(高阶函数除了可以接受函数作为参数外,还可以把函数作为结果值返回.) 举个例子:实现一个可变参数的求和. 正常的函数: de ...

  5. python面对对象编程---------6:抽象基类

    抽象基本类的几大特点: 1:要定义但是并不完整的实现所有方法 2:基本的意思是作为父类 3:父类需要明确表示出那些方法的特征,这样在写子类时更加简单明白 用抽象基本类的地方: 1:用作父类 2:用作检 ...

  6. python面对对象编程-------5:获取属性的四种办法:@property, __setattr__(__getattr__) ,descriptor

    一:最基本的属性操作 class Generic: pass g= Generic() >>> g.attribute= "value" #创建属性并赋值 &gt ...

  7. python面对对象编程------3:写集合类的三种方法

    写一个集合类的三种方法:wrap,extend,invent 一:包装一个集合类 class Deck: def __init__( self ): self._cards = [card6(r+1, ...

  8. python面对对象编程----1:BlackJack(21点)

    昨天读完了<Mastering Object-oriented Python>的第一部分,做一些总结. 首先,第一部分总过八章,名字叫Pythonic Classes via Specia ...

  9. Python学习6——再谈抽象(面对对象编程)

    1.对象魔法 在面对对象编程中,术语对象大致意味着一系列数据(属性)以及一套访问和操作这些数据的方法. 使用对象而非全局变量以及函数的原因有多个,而最重要的好处不过以下几点: 多态:可对不同类型的对象 ...

随机推荐

  1. &lpar;转&rpar;WebApi自动生成在线文档Swashbuckle

    原文地址:http://www.cnblogs.com/Arrays/p/5146194.html?utm_source=tuicool&utm_medium=referral 1.前言 1. ...

  2. python 关于 ImportError&colon; No module named 的问题

    转载自:http://my.oschina.net/leejun2005/blog/109679 今天在 centos 下安装 python setup.py install 时报错:ImportEr ...

  3. jquery实现定时调度(倒计时)

    工作需要实现了倒计时的脚本,代码如下: /** * 倒计时 * @param infoId :信息显示的id 最好是用span包裹 * @param callback:倒计时结算后的回调 */ fun ...

  4. OWIN轻量型框架介绍

    OWIN轻量型框架介绍 阅读目录 引言 框架的特色 如何启动 各项功能 静态路由的3种写法 伪静态路由的支持 处理Form表单提交的文件 流式处理Post请求的数据 多种请求类型自动识别 响应处理 请 ...

  5. servlet自动获取前端页面提交数据

    servlet自动获取前端页面jsp提交数据 以下是本人在学习过程中,因前端页面提交参数过多,后台servlet封装实体类过于麻烦而写的一个工具类,应用于jsp/servlet数据提交后,基于MVC+ ...

  6. 一张图看懂 SQL 的各种 join 用法

    下图展示了 LEFT JOIN.RIGHT JOIN.INNER JOIN.OUTER JOIN 相关的 7 种用法.   具体分解如下: 1.INNER JOIN(内连接)     2.LEFT J ...

  7. 00001 - Linux 上的 Shebang 符号&lpar;&num;&excl;&rpar;

    使用Linux或者unix系统的同学可能都对#!这个符号并不陌生,但是你真的了解它吗? 本文了将给你简单介绍一下Shebang(”#!”)这个符号. 首先,这个符号(#!)的名称,叫做”Shebang ...

  8. Android中检测字符编码(GB2312&comma;ASCII&comma;UTF8&comma;UNICODE,TOTAL——ENCODINGS&rpar;方法(二)

    Intent intent = getIntent();         String contentUri = null;         Uri uri =null;         if (in ...

  9. BZOJ1369&colon;&lbrack;Baltic2003&rsqb;Gem&lpar;树形DP&rpar;

    Description 给出一棵树,要求你为树上的结点标上权值,权值可以是任意的正整数 唯一的限制条件是相临的两个结点不能标上相同的权值,要求一种方案,使得整棵树的总价值最小. Input 先给出一个 ...

  10. 导出maven项目依赖的jar包

    注意使用mvn命令是需要配置好maven的环境变量 一.导出到自定义目录中 在maven项目下创建lib文件夹,输入以下命令: mvn dependency:copy-dependencies -Do ...