Python構(gòu)造函數(shù)與析構(gòu)函數(shù)超詳細分析
1.構(gòu)造函數(shù)
__init__(self)
, 這個方法就是構(gòu)造函數(shù),在實例化的時候自動調(diào)用。
所有如果這個函數(shù)內(nèi)有打印的方法,當實例出來的時候會打印里面的信息。
__init__
方法的第一個參數(shù)永遠都是self,表示創(chuàng)建實例本身,在__init__
方法內(nèi)部,可以把各種屬性綁定到self,因為self指向創(chuàng)建的實例本身。
有了__init__
方法,在創(chuàng)建實例的時候,就不能傳入空的參數(shù)了,必須傳入與__init__
方法匹配的參數(shù),但self不需要傳,Python解釋器自己會把實例變量傳進去。
def __init__(): pass
lass Baby: def __init__(self,name):#構(gòu)造函數(shù) self.name = name def cry(self): self.action = '哭了' print(self.action) feng = Baby('小紅') print(feng.name)#實例化時構(gòu)造函數(shù)自動執(zhí)行, print(feng.action)#cry方法未被執(zhí)行,直接調(diào)用feng.action會報錯,object has no attribute對象沒有該屬性
由于cry方法未被執(zhí)行,直接調(diào)用feng.action會報錯,object has no attribute對象沒有該屬性。解決方法有:
(1)在實例化對象后,先調(diào)用cry這個方法,在去打印feng.action屬性
class Baby: def __init__(self,name):#構(gòu)造函數(shù) self.name = name def cry(self): self.action = '哭了' print(self.action) feng = Baby('小紅') feng.cry()#先調(diào)用cry這個方法 print(feng.action)
(2)將cry這個方法放在構(gòu)造函數(shù)里,這樣實例化的時候函數(shù)會被執(zhí)行,feng.action屬性就生成了
class Baby: def __init__(self,name):#構(gòu)造函數(shù) self.name = name self.cry()#將cry這個方法放在構(gòu)造函數(shù)里 def cry(self): self.action = '哭了' print(self.action) feng = Baby('小紅') print(feng.action)
2.析構(gòu)函數(shù)
__del__(self)
, 這個方法就是析構(gòu)函數(shù),是在實例被銷毀時自動調(diào)用的。
當使用del 刪除對象時,會調(diào)用他本身的析構(gòu)函數(shù),另外當對象在某個作用域中調(diào)用完畢,在跳出其作用域的同時析構(gòu)函數(shù)也會被調(diào)用一次,這樣可以用來釋放內(nèi)存空間。
析構(gòu)函數(shù):實例被銷毀的時候執(zhí)行的,不是必須
def __del__(): pass
import pymysql class MySQL(object): def __init__(self,host,user,passwd,db,port=3306,charset='utf8'):#構(gòu)造函數(shù),類實例化的時候執(zhí)行 try: self.conn = pymysql.connect( host = host,user=user,passwd=passwd,db=db,port=port,charset=charset, autocommit=True # 自動提交,執(zhí)行insert,update語句時,可以自動提交 ) except Exception as e: print('數(shù)據(jù)庫連接失敗,%s'%e) else: self.cur = self.conn.cursor(cursor=pymysql.cursors.DictCursor) def __del__(self):#析構(gòu)函數(shù),實例被銷毀的時候執(zhí)行 self.cur.close() self.conn.close() print('數(shù)據(jù)庫連接關(guān)閉') def ex_sql(self,sql): try: self.cur.execute(sql) except Exception as e: print('sql語句錯誤,%s'%sql) else: self.res = self.cur.fetchall() return self.res #有沒有返回值都可以 my = MySQL('127.0.0.1', 'root', '123456', 'data') my.ex_sql('select * from stu') print(my.res)#可以用實例屬性取值 # print(my.ex_sql('select * from stu'))#也可以用實例方法的返回值 print('我是最后一行代碼')#執(zhí)行完最后一行代碼,數(shù)據(jù)庫連接關(guān)閉
到此這篇關(guān)于Python構(gòu)造函數(shù)與析構(gòu)函數(shù)超詳細分析的文章就介紹到這了,更多相關(guān)Python構(gòu)造函數(shù)與析構(gòu)函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python數(shù)據(jù)結(jié)構(gòu)之列表和元組的詳解
這篇文章主要介紹了python數(shù)據(jù)結(jié)構(gòu)之列表和元組的詳解的相關(guān)資料,希望通過本文能幫助到大家,讓大家徹底理解掌握這部分內(nèi)容,需要的朋友可以參考下2017-09-09Python解析Excle文件中的數(shù)據(jù)方法
今天小編就為大家分享一篇Python解析Excle文件中的數(shù)據(jù)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10Django REST framework 如何實現(xiàn)內(nèi)置訪問頻率控制
這篇文章主要介紹了Django REST framework 內(nèi)置訪問頻率控制,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-07-07使用python根據(jù)端口號關(guān)閉進程的方法
今天小編就為大家分享一篇使用python根據(jù)端口號關(guān)閉進程的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-11-11