首先,讓我來(lái)介紹一下今天的主題。今天我們將討論封裝、反射以及單例模式。除此之外,我們不再深入其他內(nèi)容。關(guān)于封裝功能,Python與Java大致相同,但寫法略有不同,因?yàn)镻ython沒有修飾符。而對(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ū)別,如果屬性以雙下劃線開頭,并且沒有聲明屬性,將無(wú)法直接訪問(wèn)。除非你動(dòng)態(tà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并沒有真正的私有屬性概念。我們可以通過(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ǔ)。