admin 管理员组

文章数量: 1087139


2024年3月10日发(作者:powerfully present翻译)

实验一 进程管理

1.1背景知识

Windows所创建的每个进程都从调用CreateProcess() API函数

开始,该函数的任务是在对象管理器子系统内初始化进程对象。每一

进程都以调用ExitProcess() 或TerminateProcess() API函数终止。

通常应用程序的框架负责调用 ExitProcess() 函数。对于C++运行

库来说,这一调用发生在应用程序的main()函数返回之后。

1、创建进程

CreateProcess()调用的核心参数是可执行文件运行时的文件名

及其命令行。表 1-1详细地列出了每个参数的类型和名称。

表1-1 CreateProcess()函数的参数

参数名称

LPCTSTR

lpApplivationName

LPCTSTR lpCommandLine

LPSECURIITY_ATTRIBUTES

lpProcessAttributes

LPSECURIITY_ATTRIBUTES

lpThreadAttributes

BOOL bInheritHandle

使用目的

全部或部分地指明包括可执行代码

的EXE文件的文件名

向可执行文件发送的参数

返回进程句柄的安全属性。主要指明

这一句柄是否应该由其他子进程所

继承

返回进程的主线程的句柄的安全属

一种标志,告诉系统允许新进程继承

创建者进程的句柄

DWORD dwCreationFlage

LPVOID lpEnvironment

特殊的创建标志 (如

CREATE_SUSPENDED) 的位标记

向新进程发送的一套环境变量;如为

null值则发送调用者环境

LPCTSTR

lpCurrentDirectory

STARTUPINFO

lpStartupInfo

LPPROCESS_INFORMATION

lpProcessInformation

新进程的启动目录

STARTUPINFO结构,包括新进程的输

入和输出配置的详情

调用的结果块;发送新应用程序的进

程和主线程的句柄和ID

可以指定第一个参数,即应用程序的名称,其中包括相对于当前

进程的当前目录的全路径或者利用搜索方法找到的路径;

lpCommandLine参数允许调用者向新应用程序发送数据;接下来的三

个参数与进程和它的主线程以及返回的指向该对象的句柄的安全性

有关。

然后是标志参数,用以在dwCreationFlags参数中指明系统应该

给予新进程什么行为。经常使用的标志是CREATE_SUSPNDED,告诉主

线程立刻暂停。当准备好时,应该使用ResumeThread() API来启动

进程。另一个常用的标志是CREATE_NEW_CONSOLE,告诉新进程启动

自己的控制台窗口,而不是利用父窗口。这一参数还允许设置进程的

优先级,用以向系统指明,相对于系统中所有其他的活动进程来说,

给此进程多少CPU时间。

接着是CreateProcess() 函数调用所需要的三个通常使用缺省

值的参数。第一个参数是lpEnvironment参数,指明为新进程提供的

环境;第二个参数是lpCurrentDirectory,可用于向主创进程发送

与缺省目录不同的新进程使用的特殊的当前目录;第三个参数是

STARTUPINFO数据结构所必需的,用于在必要时指明新应用程序的主

窗口的外观。

CreateProcess() 的最后一个参数是用于新进程对象及其主线

程的句柄和ID的返回值缓冲区。以PROCESS_INFORMATION结构中返


本文标签: 进程 参数 指明 应用程序 发送