快速進(jìn)修Python指南之面向?qū)ο蟾呒?jí)篇
簡(jiǎn)介
今天我們將討論封裝、反射以及單例模式。除此之外,我們不再深入其他內(nèi)容。關(guān)于封裝功能,Python與Java大致相同,但寫法略有不同,因?yàn)镻ython沒(méi)有修飾符。而對(duì)于反射來(lái)說(shuō),我認(rèn)為它比Java簡(jiǎn)單得多,不需要頻繁地獲取方法和屬性,而是有專門的方法來(lái)實(shí)現(xiàn)。最后,我們將簡(jiǎn)單地實(shí)現(xiàn)一下單例模式,這樣面向?qū)ο笳鹿?jié)就告一段落了。
封裝(Encapsulation)
封裝是指將數(shù)據(jù)和方法封裝在一個(gè)類中。在Python中,我們可以通過(guò)屬性和方法來(lái)實(shí)現(xiàn)封裝。屬性可以通過(guò)getter和setter方法來(lái)訪問(wèn)和修改,而方法可以在類的內(nèi)部進(jìn)行訪問(wèn)和使用。然而,與Java不同的是,雖然方法在Python中是可以調(diào)用的,但Java不允許。另外,屬性也有一些區(qū)別,如果屬性以雙下劃線開(kāi)頭,并且沒(méi)有聲明屬性,將無(wú)法直接訪問(wèn)。除非你動(dòng)態(tài)賦值,那么將失去封裝的作用。
使用雙下劃線開(kāi)頭的屬性是私有屬性,下面是一個(gè)簡(jiǎn)單的示例代碼:
class Person: def __init__(self, name, age): self.__name = name # def get_name(self): return self.__name def set_name(self, name): self.__name = name person = Person("xiaoyu") print(person.get_name()) # 輸出:xiaoyu
我們都是學(xué)習(xí)Java的,所以對(duì)于getter和setter方法的使用應(yīng)該是基本常識(shí)了。記住在Python中,我們使用雙下劃線來(lái)定義私有屬性,但實(shí)際上這只是一種約定,Python并沒(méi)有真正的私有屬性概念。我們可以通過(guò)一些特殊的方式來(lái)訪問(wèn)和修改私有屬性,但這違背了封裝的原則,不建議直接這樣做。
反射(Reflection)
反射是一種強(qiáng)大的編程技術(shù),它使得在運(yùn)行時(shí)可以動(dòng)態(tài)地獲取和修改對(duì)象的屬性和方法。在Python中,我們可以利用內(nèi)置的getattr()、setattr()和hasattr()等函數(shù)來(lái)實(shí)現(xiàn)反射的功能。通過(guò)反射,我們可以在運(yùn)行時(shí)根據(jù)需要獲取或修改對(duì)象的屬性和方法,從而實(shí)現(xiàn)更靈活和動(dòng)態(tài)的編程。不過(guò),我還是有原則的,畢竟Java作為一種商業(yè)生態(tài)體系成熟的編程語(yǔ)言,在各個(gè)領(lǐng)域都有著強(qiáng)大的應(yīng)用和支持,這是其他語(yǔ)言所無(wú)法比擬的。
下面是一個(gè)簡(jiǎn)單的示例代碼:
class MyClass: def __init__(self, name): self.name = name def hello(self): print("Hello, {}!".format(self.name)) def dance(self): print("dance, {}!".format(self.name)) def cmd(self): method_name = input("====>") if hasattr(obj, method_name): method = getattr(obj, method_name) method() obj = MyClass("xiaoyu") obj.cmd()
這樣就可以獲取到方法然后去實(shí)現(xiàn)反射了,我就不演示setattr了,自行演示吧。
單例模式(Singleton)
單例模式是一種常用的設(shè)計(jì)模式,它可以確保一個(gè)類只有一個(gè)實(shí)例,并且提供一個(gè)全局訪問(wèn)點(diǎn),方便其他對(duì)象對(duì)該實(shí)例進(jìn)行調(diào)用。在Python中,我們可以通過(guò)使用模塊級(jí)別的變量來(lái)實(shí)現(xiàn)單例模式,這種方式非常簡(jiǎn)潔和高效。
下面是一個(gè)簡(jiǎn)單的示例代碼,展示了如何在Python中實(shí)現(xiàn)單例模式:
class Singleton: _instance = None @classmethod def get_instance(cls): if not cls._instance: cls._instance = cls() return cls._instance s1 = Singleton.get_instance() s2 = Singleton.get_instance() print(s1 is s2) # 輸出: True
與Java相似,Python中也可以使用classmethod裝飾器來(lái)實(shí)現(xiàn)方法,只是在Python中我們稱之為裝飾器而非注解。
另外,Python中也有一種類似于Java中常用的stream流處理for循環(huán)的高級(jí)用法,只不過(guò)在Python中這種寫法是倒著的。所以人們稱之為字典推導(dǎo)或列表推導(dǎo)。為了方便記憶,我一直稱之為推倒。
student = { "name": "xiaoyu", "age": 18 } [print(key + ": " + str(value)) for key, value in student.items() if key == "name"] # 輸出 name: xiaoyu
總結(jié)
在今天的課上,我們深入討論了封裝、反射和單例模式這幾個(gè)重要的概念。我不想過(guò)多地贅述它們的細(xì)節(jié),但是請(qǐng)大家務(wù)必記住它們的基本語(yǔ)法規(guī)則,因?yàn)檫@也是面向?qū)ο笳鹿?jié)的結(jié)束。我希望大家能夠牢牢掌握這些知識(shí)點(diǎn),為未來(lái)的學(xué)習(xí)打下堅(jiān)實(shí)的基礎(chǔ)。
以上就是Java開(kāi)發(fā)者如何快速進(jìn)修Python指南之面向?qū)ο蟾呒?jí)篇的詳細(xì)內(nèi)容,更多關(guān)于Python面向?qū)ο蟮馁Y料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
pymysql.err.DataError:1366的報(bào)錯(cuò)解決
通過(guò)python把數(shù)據(jù)同步至mysql數(shù)據(jù)庫(kù)的過(guò)程中,遇到錯(cuò)誤,本文主要介紹了pymysql.err.DataError:1366的報(bào)錯(cuò)解決,具有一定的參考價(jià)值,感興趣的可以了解一下2024-05-05使用Python3中的gettext模塊翻譯Python源碼以支持多語(yǔ)言
這篇文章主要介紹了使用Python3中的gettext模塊翻譯Python源碼以支持多語(yǔ)言,其中翻譯Python源碼只是作為示例以展示gettext的功能和用法,需要的朋友可以參考下2015-03-03Python中的random函數(shù)實(shí)例詳解
random模塊提供生成偽隨機(jī)數(shù)的函數(shù),在使用時(shí)需要導(dǎo)入random模塊,這篇文章主要介紹了Python中的random函數(shù),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-02-02Python基于Gensim實(shí)現(xiàn)文本相似度/匹配/查重
Gensim是基于Python語(yǔ)言的自然語(yǔ)言處理庫(kù),用來(lái)主題建模、文本相似度等文本處理任務(wù),下面我們就來(lái)看看如何使用Gensim實(shí)現(xiàn)文本相似度/匹配/查重等操作吧2024-03-03PyQt5 QThread倒計(jì)時(shí)功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了PyQt5 QThread倒計(jì)時(shí)功能的實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04python數(shù)據(jù)類型的詳細(xì)分析(附示例代碼)
這篇文章主要給大家介紹了關(guān)于python數(shù)據(jù)類型分析的相關(guān)資料,python里可以通過(guò)type()函數(shù)來(lái)查看數(shù)據(jù)類型,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-09-09