欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python深入淺出分析元類

 更新時間:2022年07月21日 09:20:06   作者:Flyme?awei  
在Python里一切都是對象(object),基本數(shù)據(jù)類型,如數(shù)字,字符串,函數(shù)都是對象。對象可以由類(class)進行創(chuàng)建。那么既然一切都是對象,那么類是對象嗎?是的,類也是對象,那么又是誰創(chuàng)造了類呢?答案也很簡單,也是類,一個能創(chuàng)作類的類,稱之為(type)元類

一、類和對象

Python屬于動態(tài)類型的語言,而動態(tài)語言和靜態(tài)語言最大的不同,就是函數(shù)和類的定義,不是編譯時創(chuàng)建的,而是運行時動態(tài)創(chuàng)建的,比方說我們要定義一個 Person 的class,就寫一個 Person.py 模塊:

# -*- coding: utf-8 -*-
# 文件名  : Person.py
class Person(object):
    def say(self, s='元類'):
        print('今日學(xué)習(xí):%s' % s)
if __name__ == '__main__':
    p = Person()
    p.say()

當(dāng)Python解釋器載入 Person 模塊時,就會依次執(zhí)行該模塊的所有語句,執(zhí)行結(jié)果就是動態(tài)創(chuàng)建出一個 Person 的class對象,測試如下,(注意,是引入一個Person.py腳本)

# 文件名 :測試.py
# 引入模塊,需要模塊的路徑
from Person import Person
# 創(chuàng)建一個Person類的實例
p = Person()  
p.say('Python中的元類')  # 調(diào)用say方法
# 今日學(xué)習(xí):Python中的元類
print(type(p))  # 把實例 p 的類型打印出來
# <class 'say.Person'>
print(type(Person))  # Person 類的類型打印出來
# <class 'type'>

這里是用來 type() 函數(shù),可以查看一個類型或變量,的類型, Person 是一個class,它的類型就是 type ,而 p是一個實例,它的類型就是class Person

二、type類

我們說class的定義是運行時動態(tài)創(chuàng)建的,而創(chuàng)建class的方法就是使用 type() 函數(shù)

type() 函數(shù)既可以返回一個對象的類型,又可以創(chuàng)建出新的類型,比如,我們可以通過 type() 函數(shù)創(chuàng)建出Person 類,而無需通過 class Person(object)... 的定義,此時type的第二種用法,我們只要type傳object是可以返回該對象類型的,但是當(dāng)我們的type存在三位參數(shù)存在時

# type 類
class type(object):
    """
    type(object_or_name, bases, dict)
    type(object) -> the object's type
    type(name, bases, dict) -> a new type
    """
#參數(shù)介紹
"""    
type(object_or_name, bases, dict)
object-or-name -- 對象或類的名稱。
bases -- 基類的元組。
dict -- 字典,類內(nèi)定義的命名空間變量。
"""
# 返回新的類型對象。
# -*- coding: utf-8 -*-
def fun(self, s):
    print('hello'+s)
Hello = type('hello', (object,), dict(func=fun))
if __name__ == '__main__':
    h = Hello()
    h.func(' word')
    # hello word
    print(type(h))
    # <class '__main__.hello'>
    print(type(Hello))
    # <class 'type'>  

我們通過 type() 函數(shù)創(chuàng)建的類和直接寫class是完全一樣的,因為Python解釋器遇到class定義時,僅僅是掃描一下class定義的語法,然后調(diào)用 type() 函數(shù)創(chuàng)建出class

在正常情況下,我們都用 class Xxx... 來定義類,但是, type() 函數(shù)也允許我們動態(tài)創(chuàng)建出類來,也就是說,動態(tài)語言本身支持運行期動態(tài)創(chuàng)建類,這和靜態(tài)語言有非常大的不同,要在靜態(tài)語言運行期創(chuàng)建類,必須構(gòu)造源代碼字符串再調(diào)用編譯器,或者借助一些工具生成字節(jié)碼實現(xiàn),本質(zhì)上都是動態(tài)編譯,會非常復(fù)雜

三、元類Metaclass

除了使用 type() 動態(tài)創(chuàng)建類以外,要控制類的創(chuàng)建行為,還可以使用metaclass,也就是元類

當(dāng)我們定義了類以后,就可以根據(jù)這個類創(chuàng)建出實例,所以:先定義類,然后創(chuàng)建實例

但是如果我們想創(chuàng)建出類呢?那就必須根據(jù)metaclass創(chuàng)建出類,所以:先定義metaclass,然后創(chuàng)建類,元類就是用來創(chuàng)建這些類(對象)的,元類就是類的類

我們先看一個簡單的例子,這個metaclass可以給自定義的類增加一個 add 方法定義 ListMetaclass ,按照默認(rèn)習(xí)慣,metaclass的類名總是以Metaclass結(jié)尾,以便清楚地表示這是一個metaclas。

四、自定義一個元類

class UpperMetaclass(type):
    def __new__(mcs, class_name, class_parents, class_attrs):
        new_attrs = {}
        for name, value in class_attrs.items():
            if not name.startswith('__'):  # 判斷是否為非私有屬性
                new_attrs[name.upper()] = value
        # 直接調(diào)用type 來創(chuàng)建一個類
        return type.__new__(mcs, class_name, class_parents, class_attrs)
# 測試
class Emp(object, metaclass=UpperMetaclass):
    name = '張三'
    acl = 500
if __name__ == '__main__':
    print(hasattr(Emp, 'name'))  # 判斷Emp中是否有名字為name
    print(hasattr(Emp, 'NAME'))  # 判斷Emp中是否有名字為NAME

到此這篇關(guān)于Python深入淺出分析元類的文章就介紹到這了,更多相關(guān)Python元類內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python pass 語句使用示例

    Python pass 語句使用示例

    這篇文章主要介紹了Python pass 語句的使用方法示例,需要的朋友可以參考下
    2014-03-03
  • Python?OpenCV識別行人入口進出人數(shù)統(tǒng)計

    Python?OpenCV識別行人入口進出人數(shù)統(tǒng)計

    本文主要介紹了Python?OpenCV識別行人入口進出人數(shù)統(tǒng)計,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧<BR>
    2023-01-01
  • Python批量模糊匹配的3種方法實例

    Python批量模糊匹配的3種方法實例

    模糊匹配可以算是現(xiàn)代編輯器的一個必備特性了,它所做的就是根據(jù)用戶輸入的部分內(nèi)容,猜測用戶想要的文件名,并提供一個推薦列表供用戶選擇,下面這篇文章主要給大家介紹了關(guān)于Python批量模糊匹配的3種方法,需要的朋友可以參考下
    2022-03-03
  • Python bisect模塊原理及常見實例

    Python bisect模塊原理及常見實例

    這篇文章主要介紹了Python bisect模塊原理及常見實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-06-06
  • Python 網(wǎng)絡(luò)編程起步(Socket發(fā)送消息)

    Python 網(wǎng)絡(luò)編程起步(Socket發(fā)送消息)

    現(xiàn)在開始學(xué)習(xí)網(wǎng)絡(luò)編程,先從簡單的UDP協(xié)議發(fā)送消息開始。我們需要有接受消息的服務(wù)端程序(Server.py)和發(fā)送消息的客戶端程序(Client)。
    2008-09-09
  • 聊聊python中not 與 is None的區(qū)別

    聊聊python中not 與 is None的區(qū)別

    這篇文章主要介紹了在python中not 與 is None的區(qū)別,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • python?aeon庫進行時間序列算法預(yù)測分類實例探索

    python?aeon庫進行時間序列算法預(yù)測分類實例探索

    這篇文章主要介紹了python?aeon庫進行時間序列算法預(yù)測分類實例探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-02-02
  • python機器學(xué)習(xí)GCN圖卷積神經(jīng)網(wǎng)絡(luò)原理解析

    python機器學(xué)習(xí)GCN圖卷積神經(jīng)網(wǎng)絡(luò)原理解析

    這篇文章主要為大家介紹了GCN圖卷積神經(jīng)網(wǎng)絡(luò)原理及代碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • python 兩個一樣的字符串用==結(jié)果為false問題的解決

    python 兩個一樣的字符串用==結(jié)果為false問題的解決

    這篇文章主要介紹了python 兩個一樣的字符串用==結(jié)果為false問題的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • Python利用Selenium實現(xiàn)彈出框的處理

    Python利用Selenium實現(xiàn)彈出框的處理

    經(jīng)常出現(xiàn)在網(wǎng)頁上的基于JavaScript實現(xiàn)的彈出框有三種,分別是?alert、confirm、prompt?。本文主要是學(xué)習(xí)如何利用selenium處理這三種彈出框,感興趣的可以了解一下
    2022-06-06

最新評論