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-09
Python解析Excle文件中的數(shù)據(jù)方法
今天小編就為大家分享一篇Python解析Excle文件中的數(shù)據(jù)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10
Django 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

