亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python如何面向對象

發布時間:2020-09-24 11:43:15 來源:億速云 閱讀:146 作者:Leah 欄目:編程語言

這期內容當中小編將會給大家帶來有關Python如何面向對象,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

Python 是一門完全面向對象的語言。在 Python 中,一切都是對象。從我們開始使用 Python 時,我們就已經使用了 Python 中的對象和類。

Python 程序中的每一個元素都是類的一個實例,如數字、字符串、列表、字典這些元素,都是 Python 內置類對應的一個對象,甚至于使用 def 關鍵字定義的一個函數都對應一個 function類。

面向對象基礎

Python 使用 class 關鍵字聲明一個類。

一個典型的 Python 類主要包含以下成員:

構造函數 (constructor)

實例屬性 (Instance Attributes)

類屬性 (Class Attributes)

方法 (Class Attributes)

一個類也可以沒有任何成員,如下面的 Car 類就沒有任何成員:

class Car:
    '''This is an empty Car Class'''
    pass

下面的類則包含了實例屬性、類屬性、構造函數、方法等成員:

class Car:
    brand = 'BenChi'

    def __init__(self):
        self.price = 10000
        self.chair = 7

    def run(self):
        print('Run 100km Per Hour....')

構造函數

在 Python 中,構造函數是實例化一個類對象的時自動被調用的函數,類似于 Java 或 C# 中的構造函數。構造函數必須使用一個特定的名稱 __init__ ,并且必須有一個固定的參數 self 。

Python 類中 幾乎 每一個方法都要將 self 作為第一個參數,self 是調用該方法的對象的引用。其實,第一個參數的名字是任意的,并不一定要叫 self, self 只是一種約定。

注意,注意,注意: __init__ 方法并不是 Python 類構造函數,關于 Python 類的構造函數其實有很大爭議,這里主要是為了介紹面向對象的概念。

下面的例子定義了一個構造函數:

class Car:
    def __init__(self):
        print('Call Constructor......')

car1 = Car()
car2 = Car()

Python 中構造函數( init )的作用定義了類實例的屬性,并對實例屬性進行復制。

實例屬性

實例屬性是與類實例綁定的屬性,其定義在構造函數( init )中。

下面的例子定義了兩個實例屬性:

class Car:
    def __init__(self):
        self.price = 100
        self.chair = 7

類屬性

類屬性不同于實例屬性,類屬性的值被所有實例對象共享。類屬性在類級別定義而不是定義在__init__ 方法中。類屬性的訪問也不同于實例屬性,類屬性的訪問是通過類名, 也可以通過實例訪問。

下面例子定義了一個類屬性

class Car:
    brand = "benchi"

print(Car.brand)

通過類名修改類屬性

通過類名修改類屬性,那么該類所有的實例對象對應的類屬性都會被修改, 如下:

class Car:
    brand = "benchi"


car1 = Car()
car2 = Car()

print('Before Change.............')
print(f'car1 brand is: {car1.brand}')
print(f'car2 brand is: {car2.brand}')

print('Change Class Attribute By [Class Name]')
Car.brand = 'Audi'

print('After Change.............')
print(f'car1 brand is: {car1.brand}')
print(f'car2 brand is: {car2.brand}')

輸出:
Before Change.............
car1 brand is: benchi
car2 brand is: benchi
Change Class Attribute By [Class Name]
After Change.............
car1 brand is: Audi
car2 brand is: Audi

類方法

在一個類中,可以定義盡可能多的類方法,一般情況下,類方法的第一個參數都是 self 。

下面的類就定義了一個類方法:

class Car:
    brand = "benchi"

    def run(self):
        print('Run......')

面向對象之封裝

面向對象語言,如Java、C++等,使用 public 、 protected 、 private 等關鍵字來控制對類資源的訪問。

類的 private 成員僅能在類內部進行訪問,其他任何地方都不能訪問,包括其子類。

類的 protected 成員可以在類內部和其子類中訪問。

類的 public 成員可以在任何地方進行訪問。

Python沒有使用關鍵字機制來限制對類成員方法和類成員屬性的訪問,Python規定了一種約定,在類方法或者類成員前加 _ (下劃線)或者 __ (雙下劃線)來模擬 private 或者 public 訪問修飾其的功能。

面向對象之繼承

在面向對象編程中,繼承是達到代碼重用目的的一種方式。在繼承中,子類可以使用其父類的一部分代碼。

繼承的基本使用

下面先創建一個父類, 代碼如下:

class Fish:
    def __init__(self, first_name, last_name="Fish",
                 skeleton="bone", eyelids=False):
        self.first_name = first_name
        self.last_name = last_name
        self.skeleton = skeleton
        self.eyelids = eyelids

    def swim(self):
        print("The fish is swimming.")

    def swim_backwards(self):
        print("The fish can swim backwards.")

接下來,創建一個沒有任何方法和屬性的子類,代碼如下:

class Trout(Fish):
    pass

Python類繼承的語法是在定義類的時候,傳入父類的名字作為參數

由于 Trout 類繼承了 Fish 類, Trout 類就是 Fish 類的子類, Trout 類的對象就可以調用其父類的所有方法,代碼如下:

terry = Trout("Terry")
print(terry.first_name + " " + terry.last_name)
print(terry.skeleton)
print(terry.eyelids)
terry.swim()
terry.swim_backwards()

輸出:

Terry Fish
boneFalseThe fish is swimming.
The fish can swim backwards.

接下來,再創建另一個子類,該子類有自己的方法:

class Clownfish(Fish):

    def live_with_anemone(self):
        print("The clownfish is coexisting with sea anemone.")

創建 Clownfish 的一個對象,并調用其方法:

class Clownfish(Fish):

    def live_with_anemone(self):
        print("The clownfish is coexisting with sea anemone.")

casey = Clownfish("Casey")
print(casey.first_name + " " + casey.last_name)
casey.swim()
casey.live_with_anemone()

輸出:
Casey Fish
The fish is swimming.
The clownfish is coexisting with sea anemone.

從輸出結果可以看出, Clownfish 的對象 casey 可以調用其父類的 swim() 方法和 __init__() 方法,同時可以調用它自身的 live_with_anemone() 方法。

上述就是小編為大家分享的Python如何面向對象了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

义乌市| 湘乡市| 梅州市| 华坪县| 静海县| 滨海县| 松溪县| 双辽市| 昌黎县| 墨竹工卡县| 长宁区| 进贤县| 高邑县| 东莞市| 平山县| 武汉市| 三原县| 卢湾区| 渑池县| 彭阳县| 新民市| 北海市| 桃江县| 民乐县| 托克逊县| 阿巴嘎旗| 竹山县| 娄底市| 沾化县| 太湖县| 磐安县| 肇东市| 四子王旗| 永嘉县| 深圳市| 德清县| 乌拉特中旗| 抚顺市| 苗栗县| 双桥区| 平陆县|