句柄

✍ dations ◷ 2025-04-06 02:26:23 #数据结构

在程序设计中,句柄(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()在内存中申请缓冲区,做到内存页对齐(从而硬盘扇区也对齐)。

相关

  • 阿巴拉契科拉河阿巴拉契科拉河(Apalachicola River)是位于美国佛罗里达州的一条河流,是ACF河系的河流之一,长度180公里,流域面积19,500平方英里(50,505平方千米)。阿巴拉契科拉河的源头是佛罗里达
  • torr托(符号为Torr),与毫米汞柱(符号为mmHg)近乎等价,为压强、压力的单位,但并非国际单位制单位 (SI unit) 的成员之一。原本的 1 mmHg 是指“将幼细直管内的水银顶高一毫米之压力”,而正
  • 毛克板块毛克板块是位于新畿内亚西部的小型板块,东面与木百灵板块形成聚合板块边缘,南面与澳洲板块和鸟首板块形成转形断层。
  • 列宁格勒-大诺夫哥罗德攻势波罗的海 – 黑海 – 北极 – (跳马 – PQ-17船团 – 仙境)1941年巴巴罗萨 – (比亚韦斯托克及明斯克 – 斯摩棱斯克 – 乌曼 – 列宁格勒 – 第一次基辅 – 塞瓦斯托波尔围
  • 中国篮球协会中国篮球协会是全国性群众体育组织,中华全国体育总会的下属会员,主管篮球运动,成立于1956年6月。1997年11月24日国家体育总局篮球管理中心成立,当时与中国篮协一个机构两块牌子,
  • 恩斯特·费尔恩斯特·费尔(Ernst Fehr,1956年6月21日-)是奥地利经济学家。他是瑞士苏黎世大学微观经济学和实验经济学教授、经济系主任。他的研究领域是人类合作和社交的演化,尤其是社会正义
  • 性别中立性别中立(英语:Gender neutrality)运动。一般是指推行去性别化的语言、社会政策和其他社会机构(社会结构、性别角色或性别认同)应该避免根据人们的性别来区分性别角色的想法,以避
  • 梦想的声音 (第二季) 中国浙江卫视首播 台湾八大电视首播 台湾八大综合台首播《梦想的声音》是一档中国电视音乐节目,第二季于2017年10月27日起播出。本季四组常驻导师为羽泉、林忆莲、林俊杰和
  • 飞扬的音符 (华视综艺节目)《飞扬的音符》是中华电视公司(华视)1990年代综艺节目,华视旗下艺人轮流主持。
  • 一元一元或$1可以指: