Python中整數(shù)的緩存機(jī)制講解
在python中,如下代碼結(jié)果一定不會(huì)讓你吃驚:
Python 3.3.2 (v3.3.2:d047928ae3f6, May 16 2013, 00:06:53) [MSC v.1600 64 bit (AMD64)] on win32 Type "copyright", "credits" or "license()" for more information. >>> a=345 >>> b=a >>> a is b True >>>
沒(méi)錯(cuò),在python一切皆是對(duì)象,而對(duì)象是通過(guò)引用傳遞的。在賦值時(shí),不管這個(gè)對(duì)象是新創(chuàng)建的,還是一個(gè)已經(jīng)存在的,都是將該對(duì)象的引用賦值給變量。故這里a實(shí)際上和b是同一個(gè)對(duì)象,a is b為true!
當(dāng)然稍為了解python的人我相信都會(huì)知道以上相關(guān)知識(shí)的。但是如下的代碼結(jié)果,卻讓人不大好理解了:
>>> c=256 >>> d=256 >>> c is d True >>> e=257 >>> f=257 >>> e is f False >>>
我們將c賦值為了整型值256,d也為256,e為257,f為257。但是當(dāng)把c與d,e與f進(jìn)行is操作時(shí),卻發(fā)現(xiàn)兩者的結(jié)果不同。
原因在哪?
——這個(gè)是由python中的整型對(duì)象的緩沖池機(jī)制,所決定的。
在python中幾乎所有的內(nèi)建對(duì)象,都會(huì)有自己所特有的對(duì)象池機(jī)制。
1.小整數(shù)對(duì)象——小整型對(duì)象池
在實(shí)際編程中,數(shù)值比較小的整數(shù),比如1,2,29等,可能會(huì)非常頻繁的出現(xiàn)。而在python中,所有的對(duì)象都存在與系統(tǒng)堆上。想想?如果某個(gè)小整數(shù)出現(xiàn)的次數(shù)非常多,那么python將會(huì)出現(xiàn)大量的malloc/free操作,這樣大大降低了運(yùn)行效率,而且會(huì)造成大量的內(nèi)存碎片,嚴(yán)重影響Python的整體性能。
在python2.5乃至3.3中,將小整數(shù)位于[-5,257)之間的數(shù),緩存在小整型對(duì)象池中。
這也就是為了c is d而e is not f的原因了。
2.大整數(shù)對(duì)象——通用整數(shù)對(duì)象池
由以上知,python把小整型數(shù)完全的緩存在了小對(duì)象緩存池中了。而那些大整數(shù)對(duì)象就沒(méi)有那么好的待遇了!python運(yùn)行環(huán)境提供了一塊內(nèi)存空間供大整數(shù)輪流使用。通常稱為通用整數(shù)對(duì)象池。這也就是說(shuō)大整數(shù)其實(shí)也是有緩存的。該對(duì)象池使用鏈表組織,雖然e和f有著相同的值,但是在鏈表中確是不同的節(jié)點(diǎn)。也就是說(shuō)e和f根本不是一個(gè)對(duì)象。至于既然有緩存,為什么e和f還要組織為兩個(gè)節(jié)點(diǎn),就不大明白了。
講講我的看法吧:我覺(jué)得從語(yǔ)義上來(lái)講e=257和f=257本身就是應(yīng)當(dāng)為兩個(gè)不同的對(duì)象(這點(diǎn)和對(duì)象賦值不同)。由于整數(shù)緩存池的存在,讓大家覺(jué)得任何整數(shù)在緩沖池中都只能存在一個(gè),不能重復(fù)。但將e和f在整數(shù)緩沖池中組織為一個(gè)節(jié)點(diǎn)或兩個(gè)節(jié)點(diǎn)沒(méi)有什么本質(zhì)區(qū)別吧(除了浪費(fèi)了一點(diǎn)內(nèi)存)。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
使用Python在Windows下獲取USB PID&VID的方法
今天小編就為大家分享一篇使用Python在Windows下獲取USB PID&VID的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-07-07
python爬取NUS-WIDE數(shù)據(jù)庫(kù)圖片
本文給大家分享的是使用Python制作爬蟲(chóng)爬取圖片的小程序,非常的簡(jiǎn)單,但是很實(shí)用,有需要的小伙伴可以參考下2016-10-10
Python實(shí)現(xiàn)從url中提取域名的幾種方法
這篇文章主要介紹了Python實(shí)現(xiàn)從url中提取域名的幾種方法,本文給出了3種方法實(shí)現(xiàn)在URL中提取域名的需求,需要的朋友可以參考下2014-09-09
python print出共軛復(fù)數(shù)的方法詳解
在本篇內(nèi)容里小編給大家分享的是關(guān)于python print出共軛復(fù)數(shù)的方法總結(jié)內(nèi)容,有需要的讀者們可以學(xué)習(xí)下。2019-06-06
Python?selenium?find_element()示例詳解
selenium定位元素的函數(shù)/方法可以分為兩類:find_element及find_elements,下面這篇文章主要給大家介紹了關(guān)于Python?selenium?find_element()的相關(guān)資料,需要的朋友可以參考下2022-07-07
python數(shù)據(jù)結(jié)構(gòu)輸入輸出及控制和異常
這篇文章主要介紹了python數(shù)據(jù)結(jié)構(gòu)輸入輸出及控制和異常,上一章節(jié)中我們介紹了python的基礎(chǔ)數(shù)據(jù)類型和集合數(shù)據(jù)類型,這章節(jié)給大家介紹一下python的輸入輸出、控制和異常,對(duì)數(shù)據(jù)類型感興趣的同學(xué)可以查看一下文章<BR>2021-12-12
Django實(shí)現(xiàn)前臺(tái)上傳并顯示圖片功能
這篇文章主要介紹了Django實(shí)現(xiàn)前臺(tái)上傳并顯示圖片功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05

