GetCurrentProcess()与DuplicateHandle()解析

最近看源码在进程通信时遇到这个问题,在网上查了半天还是模模糊糊,于是决定总结别人的成果,整理一下,希望对需要的人有所帮助,如有不当望指出。

首先,我们介绍系统对象:

在系统中,对象分为两类:用户对象和内核对象。用户对象包括:窗口、菜单等;内核对象包括:进程对象、线程对象、文件映射对象等。标识用户对象的句柄在系统中是唯一的。因此,两个用户对象进程可通过该句柄进行交互。编程中我们常用的FindWindow()函数就是如此(该函数会返回指定窗口的句柄),该句柄我们可以称之为实句柄。为了加强系统的稳定性,内核对象句柄是进程相关的。在每一个进程中都有一个内核对象表,每一个对象的索引作为内核对象的句柄,从而实现进程相关。同一个对象在不同的进程中可能有不同的索引(就像你打开一个文件一样,每次返回的句柄是不一样的),即句柄。因此,若进行进程通信就有必要用DuplicateHandle()函数复制该句柄。该过程常用到以下两个函数:

1.GetCurrentProcess()

该函数的声明如下:

HANDLE WINAPI GetCurrentProcess(void)

功能:获得当前进程的句柄(该句柄为进程伪句柄,只能用来在进程内部使用,离开当前进程,该句柄就没什么意义了,该伪句柄不需要使用CloseHandle()来关闭)。

由此,我们可以看出,伪句柄的存在意义就在于使用方便、不会造成内存的泄漏。

2.DuplicateHandle()

BOOL DuplicateHandle(
HANDLE hSourceProcessHandle, // handle to source process
HANDLE hSourceHandle, // handle to duplicate
HANDLE hTargetProcessHandle, // handle to target process
LPHANDLE lpTargetHandle, // duplicate handle
DWORD dwDesiredAccess, // requested access
BOOL bInheritHandle, // handle inheritance option
DWORD dwOptions // optional actions
);

功能:将一个进程内的伪句柄,转化为可以用来进程间通信的实句柄(我是这么认为的)。

主要参数解析:

hSourceProcessHandle:源进程内核句柄

hSourceHandle:被传递的内核对象句柄(资源对象句柄,比如管道句柄),此为伪句柄。

hTargetProcessHandle:目标进程内核句柄

lpTargetHandle:接受内核对象句柄的地址(实句柄)

该函数由此把hSourceHandle的资源伪句柄转化为实句柄,并且复制给lpTargetHandle,通信时用lpTargetHandle指向的句柄通信。

其中,第一个很第三个参数可以相同也可以不同。既把某个进程的内核资源句柄复制给另一个进程对象,若这两个参数都为GetCurrentProcess(),则表示将该资源对象句柄(也就是第二个参数句柄)转化为实句柄,因为第一个和第三个参数相同,所以此函数只是把伪句柄转化为了实句柄。若想让两个进程通信,还需要将此转化后的实句 传递给其他进程。若第三个参数句柄不是GetCurrentProcess(),而是某个进程的实句柄,则此函数不仅把伪句柄转化成了实句柄,同时,将转化后的实句柄传递给了另 个进程(这是我个人的理解,不知道对不对?)。

你可能感兴趣的:(Windows开发)