OpenProcess

5 篇文章 0 订阅

函数功能:

函数用来打开一个已存在的进程对象,并返回进程的句柄。

函数原型:

HANDLE OpenProcess(
	DWORD dwDesiredAccess,
	BOOL bInheritHandle,
	DWORD dwProcessId
	)

参数:
1.dwDesiredAccess:

访问权限。

public const int PROCESS_ALL_ACCESS                           //所有能获得的权限
public const int PROCESS_CREATE_PROCESS = 0x0080;             //需要创建一个进程
public const int PROCESS_CREATE_THREAD = 0x0002;              //需要创建一个线程
public const int PROCESS_DUP_HANDLE = 0x0040;                 //重复使用DuplicateHandle句柄
public const int PROCESS_QUERY_INFORMATION =0x0400;           //获得进程信息的权限,如它的退出代码、优先级
public const int PROCESS_QUERY_LIMITED_INFORMATION = 0x1000;  /*获得某些信息的权限,如果获得了PROCESS_QUERY_INFORMATION,也拥有PROCESS_QUERY_LIMITED_INFORMATION权限*/
public const int PROCESS_SET_INFORMATION = 0x0200;            //设置某些信息的权限,如进程优先级
public const int PROCESS_SET_QUOTA = 0x0100;                  //设置内存限制的权限,使用SetProcessWorkingSetSize
public const int PROCESS_SUSPEND_RESUME = 0x0800;             //暂停或恢复进程的权限
public const int PROCESS_TERMINATE = 0x0001;                  //终止一个进程的权限,使用TerminateProcess
public const int PROCESS_VM_OPERATION = 0x0008;               //操作进程内存空间的权限(可用VirtualProtectEx和WriteProcessMemory) 
public const int PROCESS_VM_READ = 0x0010;                    //读取进程内存空间的权限,可使用ReadProcessMemory
public const int PROCESS_VM_WRITE = 0x0020;                   //读取进程内存空间的权限,可使用WriteProcessMemory
public const int SYNCHRONIZE = 0x00100000L;                   //等待进程终止

2.BOOL bInheritHandle:
是否继承句柄。
3.DWORD dwProcessId:
进程ID。

返回值:
如成功,返回值为指定进程的句柄。
如失败,返回值为空,可调用GetLastError获得错误代码。
注意:
在使用完所获得的进程句柄后一定要调用CloseHandle(handle)来关闭进程的句柄。

c#调用:

[DllImport("kernel32.dll", ExactSpelling = true, SetLastError = true)]
        public static extern IntPtr OpenProcess(
            int dwDesiredAccess,
            bool bInheritHandle,
            int dwProcessId
            );



 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值