day13
函數(shù)的嵌套定義
就是函數(shù)內部在定義一個新的函數(shù)
函數(shù)fn2 想使用函數(shù)fn1 內部定義的局部變量 直接把函數(shù)fn2 定義在函數(shù)fn1 內部 這樣函數(shù)fn2 可以直接訪問 函數(shù)fn1內部的變量
如果函數(shù)fn2 被定義在函數(shù)fn1 中 就成為了函數(shù)fn1中的局部變量? fn2與函數(shù)地址的對應關系就存放在 函數(shù)fn1建立起來的 局部名稱空間中 外部是無法調用函數(shù)fn2 的? 只能在函數(shù)fn1中 把他return fn2 作為函數(shù)fn1函數(shù)的返回值 這樣外部才能調用 fn2 ? 也就是一個函數(shù)對象可以作為另個函數(shù)的返回值
在外部也可以用fn2變量來接受fn1的返回值 fn2 與返回值的對應關系存放在全局名稱空間中? 返回值就等于賦值給了外部的fn2 外部fn2 與函數(shù)內部的fn2指向同一個函數(shù)地址那么函數(shù)內部的fn2 就能被外部調用了
?
global關鍵字
·將局部變量提升為全局變量 如果與全局變量有重名 就統(tǒng)一全局與局部變量如果想更改全局變量的值發(fā)生地址的變化可用global聲明該變量? 全局沒有同名變量 直接提升局部變量為全局變量
?
nonlocal
將局部的變量提升為嵌套局部變量? 必須要有同名嵌套的局部變量 就是統(tǒng)一嵌套局部與局部的同名變量
如果局部想改變嵌套局部變量的值(發(fā)生地址的變化),可以用nonlocal聲明該變量
?
開放封閉原則
在不修改原代碼與調用方式的情況下 為原函數(shù)添加新的功能
弊端 當修改源代碼的情況下? 會使其函數(shù)不具備特有的功能 而且調用方式也會隨著改變 加載后期維護的難度
?
裝飾器
# 裝飾器:滿足開放封閉原則的一個閉包應用 # @outer語法來調用outer,規(guī)定傳入被裝飾的函數(shù)對象,所以參數(shù)固定為一個,接受被裝飾的函數(shù)對象def outer(func):?
??? # 不能確定被裝飾的函數(shù)的參數(shù):來者不拒,用可邊長來接受
??? def inner(*args, **kwargs):
??????? pass? # 新功能位
??????? res = func(*args, **kwargs)? # 解壓帶給原功能
??????? pass? # 新功能位
??????? return res
??? return inner
# 使用裝飾器(outer),得到新功能(inner) # 用被裝飾的函數(shù)名去接受裝飾器的執(zhí)行結果,調用裝飾器時傳入被裝飾的函數(shù)對象
@outer? # fn = outer(fn) = inner
def fn(): pass
# 表面感覺調用的是原函數(shù),本質調用的是閉包(inner),使用fn調用和fn定義及inner需要參數(shù)統(tǒng)一
fn()
?
轉載于:https://www.cnblogs.com/huikejie/p/10785639.html
總結
- 上一篇: 分享:一款快速传输大文件、支持英文版的工
- 下一篇: 【转】漫画:Bitmap算法