国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Windows > 正文

window操作系統下的句柄機制說明

2019-11-28 02:45:17
字體:
來源:轉載
供稿:網友
WORKAREA_ADDRESS(這個字段在V$SQL_WORKAREA_ACTIVE和V$SQL_WORKAREA 中都有),表示Address of the work area handle,也就是說,它是SQL工作區域這個對象的句柄(相當于是該對象在oracle系統級別上的一個標識符(identity),類似,一個人,在中國范圍內,有一個唯一的區別于別人的身份證號。也類似鎖是對象的中介一樣。是一種表示地址的句柄)的值。Each SQL statement stored in the shared pool has one or more childcursors that are listed in theV$SQL view. V$SQL_WORKAREA lists all work areas needed by these child cursors.這句話說明,一個SQL語句(即父游標)的每個子游標(即執行計劃等)對應都有一個自己的SQL工作區域這種對象。

句柄,首先,它是在某一類對象范圍內標識其中一個對象的句柄。比如,這里的在oracle系統級別上的SQL工作區域這種對象。當一個SQL語句(即父游標)以某種執行計劃(即該SQL語句的某子游標)來進行執行時,oracle系統會為該子游標對應的SQL工作區域這個對象分配一塊內存空間(內存區域)。當該SQL語句執行完畢后,oracle系統就釋放這一塊內存空間。也就說,每一次,該SQL語句(即父游標)以該執行計劃(即該子游標)來進行執行,則oracle系統都會為該子游標對應的SQL工作區域這個對象分配一塊內存空間(內存區域)。這樣,每次oracle系統給該SQL工作區域這個對象分配的那塊內存空間的地址應該都不會一樣,但是,SQL工作區域這個對象的句柄值始終不變。這樣做的好處,是每個進程分工明確,即執行SQL語句的服務器進程每次要用一塊內存空間(即SQL工作區域)時,它就直接通過SQL工作區域這個對象的句柄來找到該SQL工作區域這個對象(用前判斷下是否已有空間分配給該對象即可)并使用它即可,而服務器進程不用去先為該對象分配一塊內存空間(內存區域)。這個給SQL工作區域對象分配一塊內存空間(內存區域)的工作就交由oracle系統中專門負責給各類對象分配一塊內存空間(內存區域)的進程來做即可。

操作系統的句柄也是這個機制原理,就是一個進程明確分工的機制。

進 程a只想使用一塊內存空間,不想自己分配該內存空間。所以進程b來做分配內存空間這個工作,并將該內存空間的地址與一個句柄(變量)的值關聯起來。這樣,進程a就可以用句柄了,它感覺用句柄好像用指針的感覺。當進程b來做釋放該內存空間這個工作后,就會將該內存空間的地址與該句柄(變量)的值間的關聯(這個關聯信息也要存放在某個變量或內存空間上的)撤銷掉。

這里說的對象(如,類的一個對象),其實質就是指一塊內存空間。

對象的理解:

1、第一種理解,對象就是一塊內存空間,進程通過句柄變量找到該內存空間。

2、第二種理解,創建一個對象就是在內存的程序區或其他什么區上創建一個用于描述該對象叫什么名字和它的句柄是多少(即保存對象名字和其句柄值)的內存結構,多個這種內存結構構成一張某個軟件(里的各個進程)可以使用的對象清單。創建一個對象時,可能會沒有馬上給該對象分配內存空間(這種內存空間在內存的什么區上,忘了)。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 确山县| 河东区| 连城县| 合山市| 河北区| 玉屏| 阳高县| 旺苍县| 东丽区| 长春市| 丰原市| 和硕县| 视频| 龙陵县| 湖南省| 都昌县| 漳平市| 孙吴县| 兰坪| 乐山市| 泰兴市| 抚州市| 莲花县| 若尔盖县| 新乡市| 桐梓县| 紫阳县| 鄂伦春自治旗| 景泰县| 临沂市| 进贤县| 探索| 老河口市| 昌邑市| 太原市| 堆龙德庆县| 澄江县| 久治县| 德安县| 汤原县| 镇平县|