python面向對象-1

来源:https://www.cnblogs.com/quguanwen/archive/2019/09/29/11188722.html
-Advertisement-
Play Games

1.面向對象的思想優點 優點: 簡化代碼 ,構建公共模板 ,擴展性強 思想: 類作為模板 ,對象通過模板實例化對象 ,對象去做事 ,抽象將顯示存在的事物使用代碼體現 2.三大特性 封裝(狹義) : 對屬性的封裝 ,對方法的封裝 繼承 1.子類擁有父類除私有內容外所有 2.對象通過子類-父類-...找 ...


1.面向對象的思想優點

  優點: 簡化代碼 ,構建公共模板 ,擴展性強

  思想: 類作為模板 ,對象通過模板實例化對象 ,對象去做事 ,抽象將顯示存在的事物使用代碼體現

 

2.三大特性

  封裝(狹義) : 對屬性的封裝 ,對方法的封裝

  繼承 

    1.子類擁有父類除私有內容外所有

    2.對象通過子類-父類-...找到自己所需要的屬性方法

    3.py3預設繼承object是新式類 , 使用c3演算法 ,print(類型.mro()) 判斷類名,查看多繼承的繼承順序

    4.super().方法 ,可以調用父類的同名方法

class Base:
    def __init__(self):
        print('BASE')


class A(Base):
    def __init__(self):
        super().__init__()
        print('A')


class B(Base):
    def __init__(self):
        super().__init__()
        print('B')


class C(A, B):
    def __init__(self):
        super().__init__()
        print('C')


C()

print(C.mro())  # 按照這個演算法順序,確定某個類的繼承順序

  多態

 

3.成員

  屬性 (__dict__查看)

    對象的屬性

    類的屬性

  方法 (dir()查看)

    普通方法

    類方法 :@classmethod 

    靜態方法 :@staticmethod 放在類中的普通函數

  屬性 (方法偽裝屬性)

    很多方法執行後獲得的是一個結果 ,不像一個動作

    @property      #偽裝屬性

    @方法名.setter    #根據傳入的values ,來改變屬性的返回值

  私有成員

    僅內部可以調用的變數或方法 ,私有屬性,私有類方法,私有對象屬性

  self與cls

    self形參是對象本身 ,當對象實例化之後 ,調用時將對象的記憶體地址給self

    cls形參是類本身

class Person:
    local = '地球'
    # 私有類屬性
    __character__ = '積極向上'

    def __init__(self, name, ad, hp, character):
        self.name = name
        self.ad = ad
        self.hp = hp
        # 私有對象屬性
        self.__character__ = character

    # 私有類方法
    def __local__(cls):
        print(cls.__character__)

    # 類方法
    @classmethod
    def Dict(cls):
        return cls.__dict__

    # 靜態方法
    @staticmethod
    def Sum(n):
        return n + 2

    # 屬性Info
    @property
    def Info(self):
        return '{}-{}-{}'.format(self.name, self.ad, self.hp)

    # 修改屬性Info
    @Info.setter
    def Info(self, values):
        if values < 100:
            self.ad = values


print(Person.__character__)
print(Person.Dict())
print(Person.Sum(2))

obj1 = Person('lucy', 10, 50, '積極向左')
print(obj1.Info)
obj1.Info = 99
print(obj1.Info)

 

4.對象的行為

  實例化對象

    1.__new__方法在記憶體開闢空間創建對象

    2.執行__init__方法初始化對象

  對象調用屬性與方法的順序

    優先在記憶體中尋找-->對象內部封裝-->類-->父類

 

5.類與類之間的關係

  依賴關係 : 相互依存性較低 ,就是一個類中需要執行動作時 ,需要其他類中的方法屬性去幫助完成 ,一般通過參數將對象進行調用

 

class Eat:
def handler(self, *args):
for i in args:
i.eat()


class Apple:
def eat(self):
print('吃蘋果')


class Pear:
def eat(self):
print('吃梨')


obj = Eat()
obj1 = Apple()
obj2 = Pear()
obj.handler(obj1, obj2)

 

  關聯關係 : 兩種事物必須是互相關聯的. 但是在某些特殊情況下是可以更改和更換的.

 

class Country:
def __init__(self, name):
self.name = name
self.pro_list = []

def add_pro(self, pro):
self.pro_list.append(pro)

def show_pro(self):
for i in self.pro_list:
print(i.name, i.cou)


class province:
def __init__(self, name, country):
self.name = name
self.cou = country


C1 = Country('火星國')

p1 = province('省1', C1.name)
p2 = province('省2', C1.name)

C1.add_pro(p1)
C1.add_pro(p2)

C1.show_pro()

  繼承關係 :就是繼承父類非私有屬性方法 ,self會先從對象中尋找方法屬性 ,當沒有的時候會去父類中尋找

 

6.介面類(約束抽象)

  介面類是繼承的一個用法 ,繼承可以讓子類擁有父類的代碼 ,防止代碼重覆 ,還可以定義一個介面類 ,僅定義介面名(函數名) ,由子類繼承去寫介面中的功能

  介面類抽象規定了相容介面 ,是的外部調用者不需要關心細節

# 介面類 ,約束子類必須擁有的方法,及參數
class Pay_Base:
def pay(self, money):
raise NotImplementedError('pay must be Implemented')


class ALpay(Pay_Base):
def pay2(self, money):
print('支付寶支付')


class WXpay(Pay_Base):
def pay(self, money):
print('微信支付')


class APpay(Pay_Base):
def pay(self, money):
print('蘋果支付')

# 支付函數,執行對象的介面類約束函數
def pay(payobj, money):
payobj.pay(money)


p1 = ALpay()

pay(p1, 100)

  

 7.反射

  反射是通過字元串去操作對象或者類或者是模塊 ,第一參數是(對象或者類或者是模塊)

  常用:

    getter()     getattr(參數1 ,'字元串')        #獲取記憶體地址

    hasattr()    hasattr(參數1 ,'字元串')        #判斷變數是否存在

import m1
class A:
    local = 'Beijing'

    def __init__(self):
        pass

    def datetime1(self):
        print('time')

a1 = A()

# 通過反射從對象獲取屬性
b = getattr(a1, 'local')

# 通過反射從類中拿屬性
c = getattr(A, 'local')

# 通過反射從對象中拿方法
d = getattr(a1, 'datetime1')

# 通過反射從模塊中拿到類B
B = getattr(m1,'B')
print(hasattr(m1,'B'))
e = B()

 

8.特殊雙下方法

  __str__與__repr__ ,不太理解,但是都可以把對象的記憶體地址轉為可讀字元串

  __call__方法 ,當對象 + () 的情況就會執行 __call__方法

class A:
def __init__(self, name):
self.name = name

def __str__(self):
return self.name

def __call__(self, *args, **kwargs):
print(args, kwargs)
return args, kwargs

def __repr__(self):
return '有str就不會執行repr'

a1 = A('lucy')

# 執行對象的__str__方法
print(a1)

# 執行__call__方法
a1(1, 2, 3, n=1, m=2)

# 直接執行對象的__repr__方法
print(repr(a1))

# 查看對象有多少個方法
print(dir(a1))

  __new__方法 ,new方法是object基類中的方法 ,是構造方法 ,開闢記憶體 ,創建對象

class A:
    def __new__(cls, *args, **kwargs):
        print('1')
        cls.name = 'LOP'
        return object.__new__(cls)  # 引用obeject的c語言創建對象功能

    def __init__(self):
        print('2')


# 第一步執行__new__方法中的內容,將返回值給對象名a1
# 第二步執行__init__初始化對象
a1 = A()
print(a1.name)
a2 = A()
print(a1 is a2)    # False 兩個對象各用記憶體

##單例模式##
class A:
__instance = None

def __new__(cls, *args, **kwargs):
if cls.__instance == None:
cls.__instance = object.__new__(cls)

# __instance從此記錄單例對象的記憶體
return cls.__instance

a1 = A()
a2 = A()
print(a1 is a2)

 

 

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 寫在前面 權重這個概念,相信對許多進行過前端開發的小伙伴來說肯定並不陌生,有時候一個樣式添加不上,我們就會一個 !important 懟上去,一切就好像迎刃而解了。但還有的時候,!important也並不能解決我們的問題,下麵請跟隨我來詳細瞭解一下css的權重吧! 探索權重 指某一因素或指標相對於某 ...
  • 1、聲明:@keyframes name{ }; 2、涉及到的屬性 animation-name:動畫名稱 animation-duration:單次動畫總時長 animation-timing-function:時間函數 animation-delay:播放前延時的時長 animation-ite ...
  • 前言 The last time, I have learned 【THE LAST TIME】一直是我想寫的一個系列,旨在厚積薄發,重溫前端。 也是給自己的查缺補漏和技術分享。 歡迎大家多多評論指點吐槽。 系列文章均首發於公眾號【全棧前端精選】,筆者文章集合詳見 "Nealyang/persona ...
  • <script> 標簽 在 HTML 中,JavaScript 代碼必須位於 <script> 與 </script> 標簽之間。 實例 註釋:舊的 JavaScript 例子也許會使用 type 屬性:<script type="text/javascript">。 註釋:type 屬性不是必需的 ...
  • 場景 Docker 私服Registry簡介與使用Docker-Compose安裝Registry: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/101567542 在上面安裝Registry後配置其客戶端以及Web UI。 註 ...
  •   AppBoxFuture的存儲引擎依賴Raft一致性協議來保證各個分區副本的一致性,如果不處理Raft日誌將不斷增長,因此需要特定的機制(定期或每處理一定數量的日誌)來回收那些無用的日誌數據。通過學習Raft協議內的Log Compaction,並參考TiKV等實現,作者初步 ...
  • 單例模式(singleton):是JAVA中最簡單的一種設計模式,屬於創建型模式。所謂單例,就是整個程式有且僅有一個實例。 特點: 構造方法私有化 在本類中實例化一個對象作為本類的屬性 對外提供一個訪問本類對象的方法 餓漢式:類載入時就載入對象 應用場景:小對象,頻繁用,高併發 特點:線程安全,比較 ...
  • 一 會話跟蹤 我們需要先瞭解一下什麼是會話!可以把會話理解為客戶端與伺服器之間的一次會晤,在一次會晤中可能會包含多次請求和響應。例如你給10086打個電話,你就是客戶端,而10086服務人員就是伺服器了。從雙方接通電話那一刻起,會話就開始了,到某一方掛斷電話表示會話結束。在通話過程中,你會向1008 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...