A. python中的單例模式與反彈機制
一。單例模式
一般情況下,類可以生成任意個實例,而單例模式只生成一個實例
我們先用單例模式設計一個Rectangle類
然後用__new__方法設計單例模式,代碼如下
然後我們來驗證下,單例模式下是否只能生成一個實例
單例模式在程序設計中比較典型的應用場景:多個用戶同時調用某個模塊時,會生成一些日誌,我們希望這些日誌存在同一個文件內,而不是多個文件。
在生成日誌模塊我們就可以採用單例模式進行設計。
二。反射
概念:簡單來說就是可以利用字元串來映射模塊中的相應方法然後可以操作模塊中相應的方法
我們以一個飯店點菜的實際場景來理解Python的反射機制
hasatter(對象,屬性或方法名)
判斷對象中是否有某個屬性或某個方法,返回值是布爾型
getattr(對象,屬性或方法名,預設值) 判斷對象中是否有某個屬性或某個方法,如果有返回方法本身,沒有則返回預設值
setattr(對象,屬性,新值)
將實例的屬性改為新的值,如果屬性不存在則新建
我們給實例guke1加個價格屬性
B. 怎麼理解python單例模式
在聊這之前我們首先要明確的是,單例模式在實際中的意義以及在python中具有實現的價值?
當前,相信有很多人支持單例模式,也有不少人反對,尤其是在python中,目前依舊具有很大的爭議性。我們要在評論之前首先要了解單例模式
什麼是單例模式?
顧名思義:就是單個模式
單例模式是一種常見的軟體設置模式,在它的核心結構中只包含一個被稱為單例類的特殊類,通過單例模式可以保證系統中的一個類只有一個實例而且該實例易於外界訪問,從而方便對實例個數的控制並節約系統資源。如果希望在系統中某個對象只能存在一個,單例模式是最好的解決方案。
單例模式的要點有三類
某個類只能有一個實例
它必須創建這個實例
它必須自行向整個系統提供這個實例
但是從具體角度實現來說的話,又可以分為三點
單例模式的類只能提供私有的構造函數
類定義中含有一個該類的靜態私有對象
該類提供了一個靜態的共有的函數用於創建或獲取它本身的靜態私有對象
一、實例控制
單例模式會阻止其他對象實例化其自己的單例對象的副本,從而確保所有對象都訪問唯一實例。
二、靈活性
因為類控制了實例化過程,所以類可以靈活更改實例化過程。
缺點:
一、開銷
雖然數量很少,但如果每次對象請求引用時都要檢查是否存在類的實例,將仍然需要一些開銷。可以通過使用靜態初始化解決此問題。
二、可能的開發混淆
使用單例對象(尤其在類庫中定義的對象)時,開發人員必須記住自己不能使用new關鍵字實例化對象。因為可能無法訪問庫源代碼,因此應用程序開發人員可能會意外發現自己無法直接實例化此類。
三、對象生存期
不能解決刪除單個對象的問題。在提供內存管理的語言中(例如基於.NET Framework的語言),只有單例類能夠導致實例被取消分配,因為它包含對該實例的私有引用。在某些語言中(如 C++),其他類可以刪除對象實例,但這樣會導致單例類中出現懸浮引用。
常用幾種方式
通過面向的特性,簡單的構造出單例模式
123456789101112131415當用於WEB界面時,單例模式的簡單運用
web 單例模式
不過我們需要注意的是:
特殊方法__new__是一個元構造程序,每當一個對象必須被factory類實例化時,就將調用它。__new__方法必須返回一個類的實例,因此它可以在對象創建之前或之後修改類。
因為__init__在子類中不會被隱式調用,所以__new__可以用來確定已經在整個類層次完成了初始化構造。__new__是對於對象狀態隱式初始化需求的回應,使得可以在比__init__更低的一個層次上定義一個初始化,這個初始化總是會被調用。
與__init__()相比__new__()方法更像一個真正的構造器。隨著類和類型的統一,用戶可以對內建類型進行派生,因此需要一種途徑來實例化不可變對象,比如派生字元串,在這種情況下解釋器則調用類的__new__()方法,一個靜態方法,並且傳入的參數是在類實例化操作時生成的。__new__()會調用父類的__new__()來創建對象(向上代理)
·__new__必須返回一個合法的實例,這樣解釋器在調用__init__()時,就可以吧這個實例作為self傳給他。調用父類的__new__()來創建對象,正向其他語言使用new關鍵字一樣
總結
單利模式存在的目的是保證當前內存中僅存在單個實例,避免內存浪費!!!
C. selenium python怎麼封裝方法
一、常用函數的封裝
在使用selenium做web自動化測試的過程中,經常會碰到各種各樣的問題,比如:
1、頁面載入比較慢時,selenium查找元素拋出異常,導致腳本運行中止
2、寫完腳本後發現代碼邏輯不夠清晰,維護困難,降低測試效率
所以很有必要對selenium進行封裝使框架更適合公司的需求,下面是基類的封裝,主要使用單例模式,可以將業務邏輯代碼存放在不同的Python文件中
註:BASE_URL為博客園的登錄地址
四、其他
按照此模式博友可根據公司具體的業務來實現自動化測試腳本,本文拋磚引玉,如有其他更好的想法可以一起探討
D. python類的繼承和單例模式 singleton、運算符重載
@[toc]
全局只有一個實例
<font color=#03a3e3> 該實現方式在多線程察明寬場景下不安全
繼承其他類的類稱為派生類(derived class)
被其他類繼承的類稱為這些類的基類(base
class)
需要注意圓括弧中基類的順序:<font color=#03a3e3> 從左到右搜索 <font>
多繼承會導致菱形 diamond關系:有至少一個基類可以從子類經由多個繼承路徑到達
基類方法可能被多次調用
防止重復訪問,每個基類只調用一次
通過子類實例對象課調用父類已被覆敗亮蓋
慎用多繼承(二義性)
– 對已有的運算符重槐慶新進行定義,賦予其另一種功能,以適應不同的數據類型
– 運算符重載不能改變其本來寓意
– 運算符重載只是一種 「語法上的方便」 (sugar)
– 是一種函數調用的方式
E. python 怎麼判斷一個類是否被實例化,能給出代碼學習下嗎,謝謝!
這個類似於單例模式吧
print '----------------------方法1--------------------------'
#方法1,實現__new__方法
#並在將一個類的實例綁定到類變數_instance上,
#如果cls._instance為None說明該類還沒有實例化過,實例化該類,並返回
#如果cls._instance不為None,直接返回cls._instance
class Singleton(object):
def __new__(cls, *args, **kw):
if not hasattr(cls, '_instance'):
orig = super(Singleton, cls)
cls._instance = orig.__new__(cls, *args, **kw)
return cls._instance
class MyClass(Singleton):
a = 1
one = MyClass()
two = MyClass()
two.a = 3
print one.a
#3
#one和two完全相同,可以用id(), ==, is檢測
print id(one)
#29097904
print id(two)
#29097904
print one == two
#True
print one is two
#True