windows内核- 内核中进程与句柄互转(六)

句柄:HANDLE

进程结构: EPROCESS

在内核开发中,经常需要进行进程和句柄之间的互相转换。进程通常由一个唯一的进程标识符(PID)来标识,而句柄是指对内核对象的引用。在Windows内核中,EProcess结构表示一个进程,而HANDLE是一个句柄。

一、进程PID与句柄HANDLE转换

        使用函数如OpenProcessGetProcessId。通过OpenProcess(PID),返回一个句柄(HANDLE)。通过 GetProcessId(HANDLE)返回句柄对应的进程PID。

二、进程PID 与 EPROCESS结构转换

        使用函数如PsGetProcessId,PsLookupProcessByProcessId和PsGetCurrentProcess。通过PsGetProcessId(EPROCESS),获取进程PID。PsLookupProcessByProcessId 例程接受进程的进程 ID,并返回指向进程的 EPROCESS 结构的引用指针。通过PsGetCurrentProcess函数返回当前进程的EProcess结构。通过 PsGetProcessImageFileName(IN PEPROCESS pProcess),获取进程映像名称。

三、句柄HANDLE与EPROCESS结构转换

        使用函数如ObReferenceObjectByHandle和PsGetProcessId,PsLookupProcessByProcessId。ObReferenceObjectByHandle函数接受一个句柄和一个对象类型作为参数,并返回对该对象的引用。PsGetProcessId函数接受一个EProcess结构作为参数,并返回该进程的PID。

驱动开发:内核操作进线程与模块_进程模块开发-CSDN博客

  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值