句柄

✍ dations ◷ 2025-11-05 08:49:07 #数据结构

在程序设计中,句柄(handle)是Windows操作系统用来标识被应用程序所创建或使用的对象的整数。其本质相当于带有引用计数的智能指针。当一个应用程序要引用其他系统(如数据库、操作系统)所管理的内存块或对象时,可以使用句柄。

句柄与普通指针的区别在于,指针包含的是引用对象的内存地址,而句柄则是由系统所管理的引用标识,该标识可以被系统重新定位到一个内存地址上。这种间接访问对象的模式增强了系统对引用对象的控制。(参见封装)。通俗的说就是我们调用句柄就是调用句柄所提供的服务,即句柄已经把它能做的操作都设定好了,我们只能在句柄所提供的操作范围内进行操作,但是普通指针的操作却多种多样,不受限制。

客户获得句柄时,句柄不仅是资源的标识符,也被授予了对资源的特定访问权限。

在上世纪80年代的操作系统(如Mac OS和Windows)的内存管理中,句柄被广泛应用。Unix系统的文件描述符基本上也属于句柄。和其它桌面环境一样,Windows API大量使用句柄来标识系统中的对象,并创建操作系统与用户空间之间的通信渠道。例如,桌面上的一个窗体由一个HWND类型的句柄来标识。

如今,内存容量的增大和虚拟内存算法使得更简单的指针愈加受到青睐,而指向另一指针的那类句柄受到冷淡。尽管如此,许多操作系统仍然把指向私有对象的指针以及进程传递给客户端的内部数组下标称为句柄。

康奈尔大学副教授David Gries(英语:David Gries)所著的《Compiler Construction for Digital Computer》. John Wiley and Sons, New York, 1971, 491 pages, ISBN 0-471-32776-X,给出如下定义:

 (2.3.10) DEFINITION. A handle of any sentential form is a leftmost simple phrase.

在该书的中译本: D.格里斯著,仲萃豪等译:《数字计算机的编译程序构造》,科学出版社, 1976年版,给出了如下翻译:

(2.3.10)定义.任一句型的句柄就是此句型的最左简单短语。

“句”字在汉语中发gōu音时,做“查考”之义,如:句校(查考校核);句考(查考);句稽(查考;核算)。

内核对象是内存中的数据结构,由操作系统内核分配,并且只能由操作系统内核访问。内核对象的数据结构使用引用计数,计数变为0后操作系统内核就会销毁该内核对象。安全描述符(SECURITY_ATTRIBUTES结构)描述内核对象的安全性,指出内核对象的拥有者、哪些组或用户可以访问此对象。作为对照,用户对象或GDI对象(如菜单、窗口、鼠标光标等)在创建时不需要指出安全描述符。

操作系统内核中有一个全局句柄表。每个进程有自己的一个句柄表,是一个数据结构组成的数组,每个数据结构包含一个指向内核对象的指针、访问掩码、继承标识等。句柄是进程句柄表数组的下标。在32位系统中,句柄是一个32位值。64位系统中则是64位值。应用程序调用创建内核对象的API函数后,该API函数会返回一个句柄以标识操作系统内核所创建的内核对象。这个句柄可以由进程的任何线程使用。使用CloseHandle函数或者进程结束时,内核句柄表中相应项的计数值会被减1。

GetCurrentProcess函数返回当前进程的句柄,其值为-1;GetCurrentThread函数返回的句柄其值为-2。二者都是伪句柄,在进程的句柄表中没有这两项,仅代表当前进程和当前线程。

进程间共享内核对象有如下途径:

Windows操作系统提供下述API函数以访问文件或设备:

SetHandleInformation: 设置指定句柄的当前标识GetHandleInformation: 返回指定句柄的当前标识HANDLE CreateFile(                    LPCTSTR,lpFileName,                        //指向文件名的指针                    DWORD dwDesiredAccess,                     //访问模式(读/写/读写/0表示不读写仅获取文件信息)                    DWORD dwShareMode,                         //共享模式                    LPSECURITY_ATTRIBUTES lpSecurityAttributes,//用于确定如何在子进程中继承这个句柄                    DWORD dwCreationDisposition,               // 文件存在或不存在时的操作                                                                //CREATE_NEW:创建文件,如果文件存在会出错;                                                                //CREATE_ALWAYS:创建文件,如果该文件已经存在,函数将覆盖已存在的文件并清除已存在的文件属性                                                                //OPEN_EXISTING:打开已存在文件;                                                                //OPEN_ALWAYS:如果不存在就创建;                                                                //TRUNCATE_EXISTING:将现有的文件缩短为零长度。调用进程必须用GENERIC_WRITE访问模式打开文件.如果文件不存在则函数就会失败.                    DWORD dwFlagAndAttributes,                 //指定新创建文件的属性;以及文件的标志位                                                                 //FILE_ATTRIBUTE_ARCHIVE:标记为归档属性;                                                                //FILE_ATTRIBUTE_NORMAL:默认属性;文件没有被设置任何属性;仅单独使用生效。                                                                //FILE_ATTRIBUTE_HIDDEN:隐藏文件或目录;                                                                //FILE_ATTRIBUTE_OFFLINE 文件数据不可直接利用。指出文件数据已经在物理上移动到脱机存储。                                                                //FILE_ATTRIBUTE_READONLY:文件为只读;                                                                //FILE_ATTRIBUTE_SYSTEM:文件为系统文件;                                                                //FILE_ATTRIBUTE_COMPRESSED 将文件标记为已压缩,或者标记为文件在目录中的默认压缩方式                                                                 //FILE_ATTRIBUTE_TEMPORARY 文件用于临时存储;文件系统尽量把文件数据保存在内存而不是刷回主存储;临时文件不再使用后应用程序应该尽快删除临时文件。                                                                //FILE_FLAG_WRITE_THROUGH 	系统写通过任何中间缓存直接写入硬盘;系统仍然可以缓存写操作,但不得懒惰地刷回硬盘                                                                //FILE_FLAG_OVERLAPPED 	允许对文件进行]操作                                                                //FILE_FLAG_NO_BUFFERING 	禁止对文件进行缓冲处理。文件只能写入磁盘卷的扇区块                                                                //FILE_FLAG_RANDOM_ACCESS 	针对随机访问对文件缓冲进行优化                                                                //FILE_FLAG_SEQUENTIAL_SCAN 	针对从头到尾的顺序访问方式对大文件缓冲进行优化                                                                //FILE_FLAG_DELETE_ON_CLOSE 	关闭了所有打开的句柄后,文件立即被删除。特别适合临时文件。如果没有使用FILE_SHARE_DELETE,后续的打开文件的请求将会失败.                                                                //FILE_FLAG_BACKUP_SEMANTICS 指示系统文件的打开或创建将用于备份或恢复操作。系统保证调用进程如果有必要的特权(SE_BACKUP_NAME与SE_RESTORE_NAME),将忽略文件安全检查。这个标志也适用于文件夹句柄。                                                                //FILE_FLAG_POSIX_SEMANTICS 指明文件基于POSIX规则被访问。例如多个文件使用只有大小写区别的文件名(如果文件系统支持的话)。在MS-DOS与16位Windows下,由于难以兼容,需谨慎使用。                                                                //FILE_FLAG_OPEN_REPARSE_POINT 指出禁止]的行为。标志不能够和CREAT_ALWAYS一起使用.                                                                //FILE_FLAG_OPEN_NO_RECALL 指明需要文件数据,但是将继续从远程存储器中读写,不会将数据存放在本地存储器中。这个标志由远程存储系统或分层存储管理器系统使用.                  HANDLE hTemplateFile                       //如果不为0,则指定一个文件句柄,新的文件将从这个文件中复制扩展属性                   );//如果函数失败,返会值会是INVALID_HANDLE_VALUESetFilePointer();//设置文件指针位置BOOL WriteFile(                 HANDLE fFile,                  //文件句柄                 LPCVOID lpBuffer,              //数据缓存区指针                 DWORD nNumberOfBytesToWrite,   //所要写的字节数                 LPDWORD lpNumberOfBytesWritten,//用于保存实际写入字节数的存储区的指针                 LPOVERLAPPED lpOverlapped      //OVERLAPPED结构体指针                );BOOL ReadFile(                     HANDLE fFile,                  //文件句柄                     LPCVOID lpBuffer,              //数据缓存区指针                     DWORD nNumberOfBytesToRead,    //所要写的字节数                     LPDWORD lpNumberOfBytesRead,   //用于保存实际写入字节数的存储区的指针                     LPOVERLAPPED lpOverlapped      //OVERLAPPED结构体指针                    )  ;CloseHandle(hFILE); //关闭句柄GetDiskFreeSpace(); //确定扇区的尺寸

文件访问的字节数必须是扇区尺寸的整倍数。进行读和写操作的地址必须扇区位置对齐(在内存中地址对齐到扇区容量的整倍数),可用VirtualAlloc()在内存中申请缓冲区,做到内存页对齐(从而硬盘扇区也对齐)。

相关

  • 马吕斯定理马吕斯定理是法国物理学家艾蒂安-路易·马吕斯在1808年阐述的一条几何光学的定理。在均匀介质中的光线束,如果有一个共点,例如从同一个点光源发射,这样的光束称为同心光束。同
  • 阪泉之战阪泉之战是中国上古时期传说中的一场战争,由黄帝与炎帝对战,最终由黄帝击败炎帝。此传说见于《史记·五帝本纪》。《史记》相关记载如下:以与炎帝战于阪泉之野。三战,然后得其志
  • Opera68.0.3618.24(2020年3月25日,​3天前​(2020-03-25))Opera是由Opera软件为个人电脑推出的网页浏览器,用于Microsoft Windows、macOS和Linux操作系统。Opera软件为纳斯达克上市的挪
  • 行政公职局行政公职局(葡文:Direcção dos Serviços de Administração e Função Pública;葡文简称:SAFP),是澳门特别行政区政府负责研究、协调和辅助公共行政和公务员事务的部门,隶属
  • 发箍发箍用于笼住头发的头饰。发箍多用塑料制成,有时亦用金属等材料制成。发箍多为弧形。佩戴时,发箍末端通常置于耳后。发箍多为年轻女子、儿童使用。
  • 肾单位肾单位又称肾元(英语:Nephron),是肾制造尿液的基本功能单位,人体的肾脏中,约含200万个肾单位,每一个肾单位是由肾小体和肾小管所组成,肾小体包含肾丝球(glomerulus)和鲍氏囊(Bowman's c
  • 2019冠状病毒病智利疫情1月1月2月2月3月3月4月4月过去15日过去15日 2019冠状病毒病智利疫情,介绍在2019新型冠状病毒疫情中,在智利发生的情况。2020年3月3日,2019冠状病毒病疫情扩散至智利。当地时间4
  • 方东树方东树(1772年-1851年),字植之,晚号仪卫老人,安徽桐城人。为清代中期的文学家及思想家。师从桐城派古文名家姚鼐,亦为桐城派的重要人物。生于乾隆三十七年(1772年),屡试不中,五十岁以后
  • 张碧梧张碧梧(1897年-?),江苏仪征人,中国小说家,翻译家。早年家道中落,自学英文,得表兄毕倚虹之助,到上海读书,曾翻译《断指手印》、《电贼》、《人猿泰山》与《侠盗亚森·罗平》等侦探小说,在
  • 吸足蝠属吸足蝠属(吸足蝠),哺乳纲、翼手目、吸足蝠科的一属。吸足蝠科,仅1属1种,即吸足蝠。分布于马达加斯加岛。