婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Python基礎(chǔ)之元編程知識總結(jié)

Python基礎(chǔ)之元編程知識總結(jié)

熱門標(biāo)簽:手機(jī)網(wǎng)頁嵌入地圖標(biāo)注位置 開封自動外呼系統(tǒng)怎么收費(fèi) 河北防封卡電銷卡 應(yīng)電話機(jī)器人打電話違法嗎 天津電話機(jī)器人公司 電銷機(jī)器人的風(fēng)險 開封語音外呼系統(tǒng)代理商 400電話辦理哪種 地圖標(biāo)注線上如何操作

一、前言

首先說,Python中一切皆對象,老生常談。還有,Python提供了許多特殊方法、元類等等這樣的“元編程”機(jī)制。像給對象動態(tài)添加屬性方法之類的,在Python中根本談不上是“元編程”,但在某些靜態(tài)語言中卻是需要一定技巧的東西。我們來談些Python程序員也容易被搞糊涂的東西。

我們先來把對象分分層次,通常我們知道一個對象有它的類型,老早以前Python就將類型也實(shí)現(xiàn)為對象。這樣我們就有了實(shí)例對象和類對象。這是兩個層次。稍有基礎(chǔ)的讀者就會知道還有元類這個東西的存在,簡言之,元類就是“類”的“類”,也就是比類更高層次的東西。這又有了一個層次。還有嗎?

二、ImportTime vs RunTime

如果我們換個角度,不用非得和之前的三個層次使用同樣的標(biāo)準(zhǔn)。我們再來區(qū)分兩個東西:ImportTime和RunTime,它們之間也并非界限分明,顧名思義,就是兩個時刻,導(dǎo)入時和運(yùn)行時。

當(dāng)一個模塊被導(dǎo)入時,會發(fā)生什么?在全局作用域的語句(非定義性語句)被執(zhí)行。函數(shù)定義呢?一個函數(shù)對象被創(chuàng)建,但其中的代碼不會被執(zhí)行。類定義呢?一個類對象被創(chuàng)建,類定義域的代碼被執(zhí)行,類的方法中的代碼自然也不會被執(zhí)行。

執(zhí)行時呢?函數(shù)和方法中的代碼會被執(zhí)行。當(dāng)然你要先調(diào)用它們。

三、元類

所以我們可以說元類和類是屬于ImportTime的,import一個模塊之后,它們就會被創(chuàng)建。實(shí)例對象屬于RunTime,單import是不會創(chuàng)建實(shí)例對象的。不過話不能說的太絕對,因為如果你要是在模塊作用域?qū)嵗悾瑢?shí)例對象也是會被創(chuàng)建的。只不過我們通常把它們寫在函數(shù)里面,所以這樣劃分。

如果你想控制產(chǎn)生的實(shí)例對象的特性該怎么做?太簡單了,在類定義中重寫__init__方法。那么我們要控制類的一些性質(zhì)呢?有這種需求嗎?當(dāng)然有!

經(jīng)典的單例模式,大家都知道有很多種實(shí)現(xiàn)方式。要求就是,一個類只能有一個實(shí)例。

最簡單的實(shí)現(xiàn)方法是這樣的

class _Spam:
    def __init__(self):
        print("Spam!!!")

_spam_singleton =None

def Spam():
    global _spam_singleton
    if _spam_singleton is not None:
        return _spam_singleton
    else:
        _spam_singleton = _Spam()
        return _spam_singleton

工廠模式,不太優(yōu)雅。我們再來審視一下需求,要一個類只能有一個實(shí)例。我們在類中定義的方法都是實(shí)例對象的行為,那么要想改變類的行為,就需要更高層次的東西。元類在這個時候登場在合適不過了。前面說過,元類是類的類。也就是說,元類的__init__方法就是類的初始化方法。 我們知道還有__call__這個東西,它能讓實(shí)例像函數(shù)那樣被調(diào)用,那么元類的這個方法就是類在被實(shí)例化時調(diào)用的方法。

代碼就可以寫出來了:

class Singleton(type):
    def __init__(self, *args, **kwargs):
        self._instance = None
        super().__init__(*args, **kwargs)

    def __call__(self, *args, **kwargs):
        if self._instance is None:
            self._instance = super().__call__(*args, **kwargs)
            return self._instance
        else:
            return self._instance


class Spam(metaclass=Singleton):
    def __init__(self):
        print("Spam!!!")

主要有兩個地方和一般的類定義不同,一是Singleton的基類是type,一是Spam定義的地方有一個metaclass=Singleton。type是什么?它是object的子類,object是它的實(shí)例。也就是說,type是所有類的類,也就是最基本的元類,它規(guī)定了一些所有類在產(chǎn)生時需要的一些操作。所以我們的自定義元類需要子類化type。同時type也是一個對象,所以它又是object的子類。有點(diǎn)不太好理解,大概知道就可以了。

四、裝飾器

我們再來說說裝飾器。大多數(shù)人認(rèn)為裝飾器是Python里面最難理解的概念之一。其實(shí)它不過就是一個語法糖,理解了函數(shù)也是對象之后。就可以很輕易的寫出自己的裝飾器了。

from functools import wraps

def print_result(func):

    @wraps(func)
    def wrappper(*args, **kwargs):
        result = func(*args, **kwargs)
        print(result)
        return result

    return wrappper

@print_result
def add(x, y):
    return x + y
#相當(dāng)于:
#add = print_result(add)

add(1, 3)

這里我們還用到了一個裝飾器@wraps,它是用來讓我們返回的內(nèi)部函數(shù)wrapper和原來的函數(shù)擁有相同的函數(shù)簽名的,基本上我們在寫裝飾器時都要加上它。

在注釋里寫了,@decorator這樣的形式等價于func=decorator(func),理解了這一點(diǎn),我們就可以寫出更多種類的裝飾器。比如類裝飾器,以及將裝飾器寫成一個類。

def attr_upper(cls):
    for attrname,value in cls.__dict__.items():
        if isinstance(value,str):
            if not value.startswith('__'):
                setattr(cls,attrname,bytes.decode(str.encode(value).upper()))
    return cls    

@attr_upper
class Person:
    sex = 'man'

print(Person.sex) # MAN

注意普通的裝飾器和類裝飾器實(shí)現(xiàn)的不同點(diǎn)。

五、對數(shù)據(jù)的抽象–描述符

如果我們想讓某一些類擁有某些相同的特性,或者說可以實(shí)現(xiàn)在類定義對其的控制,我們可以自定義一個元類,然后讓它成為這些類的元類。如果我們想讓某一些函數(shù)擁有某些相同的功能,又不想把代碼復(fù)制粘貼一遍,我們可以定義一個裝飾器。那么,假如我們想讓實(shí)例的屬性擁有某些共同的特點(diǎn)呢?有人可能會說可以用property,當(dāng)然可以。但是這些邏輯必須在每個類定義的時候都寫一遍。如果我們想讓這些類的實(shí)例的某些屬性都有相同的特點(diǎn)的話,就可以自定義一個描述符類。

這里我們給出一些例子

class TypedField:
    def __init__(self, _type):
        self._type = _type

    def __get__(self, instance, cls):
        if instance is None:
            return self
        else:
            return getattr(instance, self.name)

    def __set_name__(self, cls, name):
        self.name = name

    def __set__(self, instance, value):
        if not isinstance(value, self._type):
            raise TypeError('Expected' + str(self._type))
        instance.__dict__[self.name] = value

class Person:
    age = TypedField(int)
    name = TypedField(str)

    def __init__(self, age, name):
        self.age = age
        self.name = name

jack = Person(15, 'Jack')
jack.age = '15'  # 會報錯

在這里面有幾個角色,TypedField是一個描述符類,的屬性Person是描述符類的實(shí)例,看似描述符是作為Person,也就是類的屬性而不是實(shí)例屬性存在的。但實(shí)際上,一旦Person的實(shí)例訪問了同名的屬性,描述符就會起作用。需要注意的是,在Python3.5及之前的版本中,是沒有__set_name__這個特殊方法的,這意味著如果你想要知道在類定義中描述符被起了一個什么樣的名字,是需要在描述符實(shí)例化時顯式傳遞給它的,也就是需要多一個參數(shù)。不過在Python3.6中,這個問題得到了解決,只需要在描述符類定義中重寫__set_name__這個方法就好了。還需要注意的是__get__的寫法,基本上對instance的判斷是必需的,不然會報錯。原因也不難理解,就不細(xì)說了。

六、控制子類的創(chuàng)建——代替元類的方法

在Python3.6中,我們可以通過實(shí)現(xiàn)__init_subclass__特殊方法,來自定義子類的創(chuàng)建,這樣我們就可以在某些情況下擺脫元類這個討厭的東西。

class PluginBase:
    subclasses = []

    def __init_subclass__(cls, **kwargs):
        super().__init_subclass__(**kwargs)
        cls.subclasses.append(cls)

class Plugin1(PluginBase):
    pass

class Plugin2(PluginBase):
    pass

小結(jié)諸如元類等元編程對于大多數(shù)人來說有些晦澀難懂,大多數(shù)時候也無需用到它們。但是大多數(shù)框架背后的實(shí)現(xiàn)都使用到了這些技巧,這樣才能讓使用者寫出來的代碼簡潔易懂。如果你想更深入的了解這些技巧,可以參看一些書籍例如《Fluent Python》、《Python Cookbook》(這篇文章有的內(nèi)容就是參考了它們),或者看官方文檔中的某些章節(jié)例如上文說的描述符HowTo,還有Data Model一節(jié)等等。或者直接看Python的源碼,包括用Python寫的以及CPython的源碼。

記住,只有在充分理解了它們之后再去使用,也不要是個地方就想著使用這些技巧。

到此這篇關(guān)于Python基礎(chǔ)之元編程知識總結(jié)的文章就介紹到這了,更多相關(guān)Python元編程內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python中用Decorator來簡化元編程的教程
  • Python中使用裝飾器和元編程實(shí)現(xiàn)結(jié)構(gòu)體類實(shí)例
  • 簡析Python函數(shù)式編程字符串和元組及函數(shù)分類與高階函數(shù)
  • python使用xpath獲取頁面元素的使用
  • 如何利用Python批量處理行、列和單元格詳解
  • Python元類與迭代器生成器案例詳解
  • Python BeautifulSoup基本用法詳解(通過標(biāo)簽及class定位元素)
  • python中使用 unittest.TestCase單元測試的用例詳解
  • Python接口自動化淺析unittest單元測試原理
  • python自動化八大定位元素講解
  • python一繪制元二次方程曲線的實(shí)例分析
  • 詳解Python自動化中這八大元素定位
  • python元組打包和解包過程詳解
  • 淺談Python的元編程

標(biāo)簽:江蘇 宿遷 蘭州 駐馬店 常州 成都 六盤水 山東

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python基礎(chǔ)之元編程知識總結(jié)》,本文關(guān)鍵詞  Python,基礎(chǔ),之元,編程,知識,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python基礎(chǔ)之元編程知識總結(jié)》相關(guān)的同類信息!
  • 本頁收集關(guān)于Python基礎(chǔ)之元編程知識總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品毛片大码女人| 在线观看91av| 99精品视频中文字幕| 日韩欧美一区在线观看| 日韩欧美一级二级三级| 欧美二区三区91| 一级女性全黄久久生活片免费| 国产一区二区三区观看| 日韩欧美一级精品久久| 麻豆国产欧美日韩综合精品二区 | 亚洲一级二级三级在线免费观看| 99这里只有久久精品视频| 国产精品久久99| 91香蕉视频污在线| 一区二区三区中文字幕| 91九色02白丝porn| 日本色综合中文字幕| 精品国产一区a| 国产成人aaa| 亚洲色大成网站www久久九九| 色综合夜色一区| 一区二区不卡在线播放 | 国产成人精品亚洲日本在线桃色| 欧美xingq一区二区| 国产成人综合亚洲网站| 国产精品美女视频| 91网站在线播放| 日韩主播视频在线| 久久久精品国产免大香伊| 99久久久久免费精品国产| 亚洲成人午夜影院| 欧美videossexotv100| 久久精品免费观看| 久久综合狠狠综合久久激情 | 免费视频一区二区| 91麻豆精品国产91| 亚洲三级在线免费观看| 久久综合成人精品亚洲另类欧美| 高清成人免费视频| 日韩国产高清在线| 欧美成人精品二区三区99精品| 美日韩一级片在线观看| 日韩码欧中文字| 欧美喷水一区二区| 丰满白嫩尤物一区二区| 亚洲成年人影院| 欧美激情一区在线| 欧美日韩在线观看一区二区 | 亚洲色图欧美偷拍| 91精品久久久久久蜜臀| 精品一区二区三区在线播放视频| 国产视频在线观看一区二区三区 | 亚洲电影你懂得| 欧美精品一区二区三区一线天视频| 丁香亚洲综合激情啪啪综合| 国产精品成人在线观看 | 欧美亚洲免费在线一区| 蓝色福利精品导航| 亚洲第一二三四区| 国产精品美女一区二区| 欧美tk丨vk视频| 制服丝袜亚洲网站| 欧洲生活片亚洲生活在线观看| 美女久久久精品| 亚洲黄色免费网站| 亚洲黄色免费网站| 中文字幕av一区二区三区免费看 | 国产精品人人做人人爽人人添| 5858s免费视频成人| 欧美自拍偷拍一区| 99久久伊人精品| 国产精品一区二区免费不卡| 午夜精品久久久久久久久| 中文字幕一区在线观看视频| 日韩欧美不卡在线观看视频| 欧美性视频一区二区三区| 欧美午夜精品免费| 成人免费高清在线观看| 不卡的av在线播放| 国产成人精品网址| 91视视频在线观看入口直接观看www | 免费成人av在线| 亚洲视频免费在线| 1024成人网| 国产精品三级av| 国产精品五月天| 国产精品入口麻豆九色| 亚洲国产精品精华液ab| 26uuu国产日韩综合| 国产精品无人区| 国产日韩精品一区二区三区| 26uuu精品一区二区| 久久蜜桃一区二区| 国产三级欧美三级| 国产欧美一区视频| 中文字幕一区三区| 午夜精品久久久久久久久久久| 午夜精品福利一区二区蜜股av| 五月婷婷综合网| 五月天一区二区三区| 狠狠色丁香婷婷综合久久片| 久久国产精品色| 99热99精品| 91九色02白丝porn| 精品久久免费看| 国产欧美日韩另类视频免费观看| 中文字幕av一区二区三区| 亚洲一线二线三线久久久| 五月激情六月综合| 韩国精品主播一区二区在线观看| 波多野结衣在线一区| 欧美日韩精品一区二区天天拍小说 | 在线免费观看视频一区| 91精品在线免费观看| 26uuu色噜噜精品一区二区| 亚洲综合激情另类小说区| 美女看a上一区| 91色|porny| 欧美精品一区二区三区蜜桃| 1024精品合集| 国产乱码精品一品二品| 色婷婷久久久亚洲一区二区三区| 日韩一级高清毛片| 亚洲乱码国产乱码精品精98午夜 | 日本一不卡视频| eeuss鲁片一区二区三区在线看| 91精品国产91久久久久久一区二区| 国产欧美一区二区在线| 捆绑紧缚一区二区三区视频 | 91精品国产综合久久精品图片| 中文字幕av一区二区三区| 黑人精品欧美一区二区蜜桃 | 欧美精品aⅴ在线视频| 中文字幕国产一区| 精品一区二区三区影院在线午夜 | 国产呦精品一区二区三区网站| 欧美综合亚洲图片综合区| 中文字幕五月欧美| 国产91丝袜在线18| 久久亚洲一区二区三区四区| 亚洲一本大道在线| 不卡av在线网| 中文字幕电影一区| yourporn久久国产精品| 国产精品欧美久久久久一区二区| 亚洲午夜视频在线观看| 91久久人澡人人添人人爽欧美| 国产精品欧美久久久久无广告| 国产成人亚洲精品狼色在线| 久久久久亚洲蜜桃| 国产一区二区三区综合| 2020国产精品| 国产精品系列在线观看| 久久亚洲春色中文字幕久久久| 捆绑紧缚一区二区三区视频| 欧美一区日韩一区| 精品一区二区免费视频| 久久亚洲精品国产精品紫薇| 久久99精品网久久| 中文成人综合网| av资源站一区| 亚洲精品欧美专区| 91精品国产综合久久香蕉麻豆 | 老司机精品视频导航| 久久久亚洲国产美女国产盗摄 | 视频一区二区欧美| 91精品综合久久久久久| 国产精品一区2区| 国产精品免费丝袜| 欧美性一区二区| 加勒比av一区二区| 中文天堂在线一区| 337p亚洲精品色噜噜噜| 国产久卡久卡久卡久卡视频精品| 国产精品免费看片| 538在线一区二区精品国产| 国产精品一区三区| 亚洲国产日韩a在线播放| 欧美日韩免费一区二区三区视频| 麻豆国产欧美日韩综合精品二区| 欧美成人激情免费网| 99久久亚洲一区二区三区青草 | 免费观看久久久4p| 国产精品网站在线观看| 欧美性xxxxxx少妇| 精品一区二区三区视频在线观看| 日本一区二区三区高清不卡| 色婷婷久久久亚洲一区二区三区| 日产欧产美韩系列久久99| 精品少妇一区二区三区在线视频| 91小视频在线| 国产激情一区二区三区四区 | 欧美成人精品福利| 在线日韩av片| 国产高清精品在线| 日韩一区精品字幕| 国产精品美女久久久久久久久久久| 91精品国产色综合久久不卡蜜臀 | 国内久久婷婷综合| 男人的天堂久久精品|