1.《python核心编程》的这段程序怎么理解?对于这个函数,书上说两个wraaped是闭包,但是不知道谁是自由变量。
2.代码:
from time import time
def logged(when):
def log(f, *args, **kwargs):
print '''Called:
function: %s
args: %r
kwargs %r''' % (f, args, kwargs)
def pre_logged(f):
def wraper(*args, **kwargs):
log(f, *args, **kwargs)
return f(*args, **kwargs)
return wraper
def post_logged(f):
def wrapped(*args, **kwargs):
now = time()
try:
return f(*args, **kwargs)
finally:
log(f, *args, **kwargs)
print "time delta: %s" % (time()-now)
return wrapped
try:
return {"pre": pre_logged, "post": post_logged}[when]
except KeyError, e:
raise ValueError(e), 'must bre "pre" or "post"'
@logged("post")
def hello(name):
print "Hello, ", name
hello('World!')
소위 클로저(Closure)는 함수 안에 정의된 함수를 말합니다. 실제로 엄밀히 말하면 위에 기록된 함수 아래의 모든 함수 정의는 클로저입니다.
클로저 정보:
인라인 함수가 외부 범위의 변수를 참조하면 클로저가 발생합니다. 클로저를 생성하려면 다음 사항이 동시에 충족되어야 합니다.
1. 인라인 함수가 있어야 합니다. 질문의 외부 함수는 pre_logged 및 post_logged이며 해당 내장 함수는 래퍼 및 래핑됩니다.
2. 인라인 함수는 외부 함수의 변수를 참조해야 합니다. 질문은 외부 args, *kwargs 매개변수를 참조합니다.
3. 외부 함수의 반환 값은 내장 함수여야 합니다. 질문에서는 반품 래퍼, 반품 포장을 사용하여 반품합니다.
데코레이터 정보:
으아아아간단히 말하면 데코레이터는 다른 기능의 기능을 수정하는 함수입니다. 질문에 로그인한 것은 귀하가 정의한 hello 함수를 장식하는 데 사용되는 데코레이터입니다.
데코레이터 매개변수로 "post"를 전달했습니다. return {"pre": pre_logged, "post": post_logged}[when]
post_logged 함수가 호출됩니다. 소요 시간( time()-지금)
데코레이터에 대한 자세한 설명은 "Python Advanced"를 참조하세요:
데코레이터에 대한 자세한 설명
이 책 전체가 잘 번역되었으니 꼭 읽어보시길 권합니다.