正 文

利用API在Windows下创建进程和线程


www.7dspace.com  更新日期:2006-1-24 5:09:04  七度空间


  前言:

  谈到在Windows创建线程的例子,在网上的很多的参考都是基于MFC的。其实,就操作系统实验这个前提而言,大可不必去碰那个大型的MFC的框架。[1]中提到了在Windows命令控制台下创建进程及线程的方法,本文对[1]中的方法加以了实现,并做些简单的进程及线程的测试程序。

  1、实验准备:

  要实验的Windows下的多线程实验,应做如下准备:

  a) 在新建中选”Win32 Console Application”An empty project

  b) 选”工程””设置”选项,在”设置”中选择“C/C++”标签,在”Project Option”中,将”MLd”参数改成“MTd”(如图1)。


图1

  以上两步对实验成功至关重要,否则,即是代码无误,在连接时同样会出现问题。

  2、Windows下进程的创建:

  在[1]中,Windows的进程和线程模型被描述成”多进程,基于单进程的多线程”。

  在创建一个线程时,Windows会做大量的工作---创建一个新的地址空间,为进程分配资源以及创建一个基线程。

  CreateProcess函数的原型如下:

CreateProcess(
 LPCTSTR lpApplicationName,
 //pointer to name of executable moudle
 LPTSTR cmdLine,
 //pointer to command line string
 LPSECURITY_ATTRIBUTES lpProcessAttributes,
 //pointer to process security attributes
 LPSECURITY_ATTRIBUTES lpThreadAttributes,
 //pointer to theread security attributes
 BOOL bInheritHandle ,
 //handle inheritance flag
 DWORD dwCreationFlag,//various creation flags
 LPVOID lpEnviroment,//Enviroment variable
 LPCTSTR lpCurrentDirectory, //Child's current directory
 LPSTARTUPINFO lpStartupInfo, //pointer to StartupInfo
 LPPROCESS_INFORMATION lpProcessInformation
 //pointer to PROCESS_INFORMATION
)

  虽然有很多参数,不过在现阶段的实验级别,大多数参数只要用默认值即可。

  下面要做的关于Windows使用进程的实验,在Linux系统下,可以使用类似:

  execve(char* cmdName , char* cmdArgu)的语句从一个程序中去执行其它的程序。

  而如果在Windows下,当使用CreateProcess去执行相应的功能时,只要去改变cmdLine中的内容即可,其它的参数使用默认值,具体见代码1:

  代码1执行的功能是从命令行中启动这个名叫的launch的测试程序,在launch后面应加上保存有需要打开程序路径的文件名:

  如在命令行中键入:

>launch set.txt

  而set.txt中的内容为:

C:\\WINDOWS\\SYSTEM32\\CALC.EXE
C:\\WINDOWS\\SYSTEM32\\NOTEPAD.EXE NEW.TXT
C:\\WINDOWS\\SYSTEM32\\CHARMAP.EXE

  路径的前半部分为”C:\\WINDOWS\\”,这当然要视你的Windows系统的类型以及系统盘的存放位置而定。如果是NT或2000的机器,则应使用WINNT.
6页,页码:[1] [2] [3] [4] [5] [6] 

上一篇:Excel中录入固定格式数据的技巧
下一篇:Windows 2000缓冲区溢出技术原理
标题:利用API在Windows下创建进程和线程 作者:EmilMatthew 来源:blog
收藏此页】【打印】【关闭
站 内 搜 索
 

热 点 导 读
特 别 推 荐