装饰器(1)


介绍

  • Python的装饰器叫Decorator,就是对一个模块做装饰。
  • 作用: 为已存在的对象添加额外功能。
  • 与Java中的注解相似,就是在方法前加@XXX来对这个方法做装饰。
  • 与Java中的注解相当复杂不同,Python的装饰器相当简单。
  • 函数式编程
  • 面向切片编程

HelloWorld

需求

def fun(i):
print i

这是一个简单的方法,现在我们要在执行这个方法前后在执行一些其他代码,比如计算运行时间。
简单的方式就是:

import time

def fun(i):
t = time.time()
print i
t = time.time() - t # 计算运行时间
print '运行时间:',str(t) # 打印时间

这种方式不方便,也不能复用。

使用函数式编程

import time 

# 计算运行时间
def exec_time(fn, i): # fn:方法; i:方法的参数
t = time.time()
fn(i) # 调用fn
t = time.time() - t # 计算运行时间
print '运行时间:',str(t) # 打印时间 def fun(i):
print i # 调用
exec_time(fun, i)

使用这种方式,在实际调用时,需要包裹一层exec_time方法,虽然可以复用,使用起来但也并不灵活。

加入装饰器

下面我们就来加入修饰器

from functools import wraps         # 引入装饰器需要的包
import time # 定义一个装饰器
def exec_time(fn): # 参数fn:要修饰的方法,就是我们的fun
@wraps(fn)
def _(i): # 修饰方法,参数i是fun传过来的参数
t = time.time()
fn(i) # 执行方法
t = time.time() - t
print '运行时间:',str(t)
return _ # 返回修饰后方法

这样就完成了一个计算运行时间的装饰器。

@exec_time
def fun(i):
print i @exec_time
def fun2(i):
print 'fun2', i

使用起来十分方便。

解析

  • 加入了@exec_time后的fun方法,在调用时会自动调用相当于exec_time(fun)的方法。
  • fun方法被exec_time装饰了,方法在开始和结束时会进行计时,并打印花费时间,这就是一个横切面,这种编程方式就是面向切面的编程。在方法执行的过程中横向插入逻辑,在很多地方都能大量减少重复代码。

本站文章为宝宝巴士 SD.Team原创,转载务必在明显处注明:(作者官方网站:宝宝巴士
转载自【宝宝巴士SuperDo团队】 原文链接: http://www.cnblogs.com/superdo/p/4829345.html

*:first-child {
margin-top: 0 !important; }
body > *:last-child {
margin-bottom: 0 !important; }

a {
color: #4183C4;
text-decoration: none; }
a.absent {
color: #cc0000; }
a.anchor {
display: block;
padding-left: 30px;
margin-left: -30px;
cursor: pointer;
position: absolute;
top: 0;
left: 0;
bottom: 0; }

h1, h2, h3, h4, h5, h6 {
margin: 20px 0 10px;
padding: 0;
font-weight: bold;
-webkit-font-smoothing: antialiased;
cursor: text;
position: relative; }

h1:hover a.anchor, h2:hover a.anchor, h3:hover a.anchor, h4:hover a.anchor, h5:hover a.anchor, h6:hover a.anchor {
background: url() no-repeat 10px center;
text-decoration: none; }

h1 tt, h1 code {
font-size: inherit; }

h2 tt, h2 code {
font-size: inherit; }

h3 tt, h3 code {
font-size: inherit; }

h4 tt, h4 code {
font-size: inherit; }

h5 tt, h5 code {
font-size: inherit; }

h6 tt, h6 code {
font-size: inherit; }

h1 {
font-size: 28px;
color: black; }

h2 {
font-size: 24px;
border-bottom: 1px solid #cccccc;
color:#00ccff;
margin: 25px auto 12px auto;
padding-bottom: 2px;
}

h3 {
font-size: 18px;
color:#993300;}

h4 {
font-size: 16px; }

h5 {
font-size: 14px; }

h6 {
color: #777777;
font-size: 14px; }

p, blockquote, ul, ol, dl, li, table, pre {
margin: 0 0; }

/*hr {
background: transparent url() repeat-x 0 0;
border: 0 none;
color: #cccccc;
height: 4px;
padding: 0;
}*/
hr {
margin: 0 0 19px;
border: 0;
border-bottom: 1px solid #ccc;
}

body > h2:first-child {
margin-top: 0;
padding-top: 0; }
body > h1:first-child {
margin-top: 0;
padding-top: 0; }
body > h1:first-child + h2 {
margin-top: 0;
padding-top: 0; }
body > h3:first-child, body > h4:first-child, body > h5:first-child, body > h6:first-child {
margin-top: 0;
padding-top: 0; }

a:first-child h1, a:first-child h2, a:first-child h3, a:first-child h4, a:first-child h5, a:first-child h6 {
margin-top: 0;
padding-top: 0; }

h1 p, h2 p, h3 p, h4 p, h5 p, h6 p {
margin-top: 0; }

li p.first {
display: inline-block; }
li {
margin: 0; }
ul, ol {
padding-left: 30px; }

ul :first-child, ol :first-child {
margin-top: 0; }

dl {
padding: 0; }
dl dt {
font-size: 14px;
font-weight: bold;
font-style: italic;
padding: 0;
margin: 15px 0 5px; }
dl dt:first-child {
padding: 0; }
dl dt > :first-child {
margin-top: 0; }
dl dt > :last-child {
margin-bottom: 0; }
dl dd {
margin: 0 0 15px;
padding: 0 15px; }
dl dd > :first-child {
margin-top: 0; }
dl dd > :last-child {
margin-bottom: 0; }

blockquote {
border-left: 4px solid #dddddd;
padding: 0 15px;
color: #777777; }
blockquote > :first-child {
margin-top: 0; }
blockquote > :last-child {
margin-bottom: 0; }

/*table {
padding: 0;border-collapse: collapse; }
table tr {
border-top: 1px solid #cccccc;
background-color: white;
margin: 0;
padding: 0; }
table tr:nth-child(2n) {
background-color: #f8f8f8; }
table tr th {
font-weight: bold;
border: 1px solid #cccccc;
margin: 0;
padding: 6px 13px; }
table tr td {
border: 1px solid #cccccc;
margin: 0;
padding: 6px 13px; }
table tr th :first-child, table tr td :first-child {
margin-top: 0; }
table tr th :last-child, table tr td :last-child {
margin-bottom: 0; }*/

img {
max-width: 100%; }

span.frame {
display: block;
overflow: hidden; }
span.frame > span {
border: 1px solid #dddddd;
display: block;
float: left;
overflow: hidden;
margin: 13px 0 0;
padding: 7px;
width: auto; }
span.frame span img {
display: block;
float: left; }
span.frame span span {
clear: both;
color: #333333;
display: block;
padding: 5px 0 0; }
span.align-center {
display: block;
overflow: hidden;
clear: both; }
span.align-center > span {
display: block;
overflow: hidden;
margin: 13px auto 0;
text-align: center; }
span.align-center span img {
margin: 0 auto;
text-align: center; }
span.align-right {
display: block;
overflow: hidden;
clear: both; }
span.align-right > span {
display: block;
overflow: hidden;
margin: 13px 0 0;
text-align: right; }
span.align-right span img {
margin: 0;
text-align: right; }
span.float-left {
display: block;
margin-right: 13px;
overflow: hidden;
float: left; }
span.float-left span {
margin: 13px 0 0; }
span.float-right {
display: block;
margin-left: 13px;
overflow: hidden;
float: right; }
span.float-right > span {
display: block;
overflow: hidden;
margin: 13px auto 0;
text-align: right; }

code, tt {
margin: 0 2px;
padding: 0 0px;
white-space: nowrap;
/*background-color: #fff;*/
color: rgba(51, 102, 255, 255);
/*border: 1px solid #eaeaea;*/
/*background-color: #f8f8f8;*/
/*border-radius: 3px; */}

pre code {
margin: 0;
padding: 0;
white-space: pre;
border: none;
color: rgba(0, 0, 0, 255);
background: transparent; }

.highlight pre {
background-color: #f8f8f8;
border: 1px solid #cccccc;
font-size: 13px;
line-height: 19px;
overflow: auto;
padding: 6px 10px;
border-radius: 3px; }

pre {
background-color: #f8f8f8;
border: 1px solid #cccccc;
font-size: 14px;
line-height: 19px;
overflow: auto;
padding: 6px 10px;
border-radius: 3px; }
pre code, pre tt {
background-color: transparent;
border: none; }

sup {
font-size: 0.83em;
vertical-align: super;
line-height: 0;
}
* {
-webkit-print-color-adjust: exact;
}
@media screen and (min-width: 914px) {
body {
/*width: 854px;*/
/*margin:0 auto;*/
}
}
@media print {
table, pre {
page-break-inside: avoid;
}
pre {
word-wrap: break-word;
}
}

#cnblogs_post_body li ul li {
list-style-type: circle !important;
}
#cnblogs_post_body a {
text-decoration: none;
color: #4183C4;
}

#mainContent .postBody h2 {
margin: 25px auto 12px auto;
padding-bottom: 2px;
}
-->

最新文章

  1. YYModel 源码解读(二)之NSObject+YYModel.h (5)
  2. SQL 语句大全(转载)
  3. 【DevOps】DevOps成功的八大炫酷工具
  4. win7 IIS7环境下部署PHP 7.0
  5. Openstack的用户登录流程
  6. Arrays 类操作 Java 的数组排序
  7. STM32库函数实现方法
  8. Amzon MWS API开发之 请求报告
  9. Latex(一)公式自动编号与自动引用
  10. 利用flashBack恢复误删除(delete)的表数据
  11. .dll 无法查找或者打开PDB文件
  12. Code4 APP
  13. Windows环境下在IDEA编辑器中spark开发安装步骤
  14. ELK+Redis+Nginx服务数据存储以及Nginx日志的收集
  15. ASP.NET WebAPI 集成 Swagger 启用 OAuth 2.0 配置问题
  16. Project Euler Problem8
  17. 把tree结构数据转换easyui的columns
  18. Install kubernetes without yum
  19. ZOJ 4027 Sequence Swapping(DP)题解
  20. 编码风格和PEP8规范

热门文章

  1. DAG的深度优先搜索标记
  2. 【华为云技术分享】智能诊断和优化,华为云DAS服务云DBA平台让您无忧运维
  3. CF#214 C. Dima and Salad 01背包变形
  4. CF#633 C. Powered Addition 思维
  5. Python Web自动化测试入门与实战,从入门到入行
  6. HTTP Strict Transport Security (通常简称为HSTS)
  7. Flash 被禁止运行的方法
  8. electron——通知
  9. python --字符串学习
  10. layui 关闭弹出层方法