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