实验一 进程创建与终止

实验一 进程创建与终止

实验目的

利用Windows提供的API函数,编写程序,实现进程的创建和终止(如创建写字板进程及终止该进程),加深对操作系统进程概念的理解,观察操作系统进程运行的动态性能,获得包含多进程的应用程序编程经验。

实验内容

  1. CreateProcess()函数原型及参数解释:
   BOOL CreateProcess(
           LPCTSTR lpApplicationName,//windows的可执行程序,是一个exe格式文件,为NULL则会调用cmd.exe进程
           LPTSTR lpCommandLine,//执行命令行参数
           LPSECURITY_ATTRIBUTES lpProcessAttributes,//指向SECURITY_ATTRIBUTES 结构的指针,用来决定返回的进程对象能否被子进程继承,如果为NULL,则不可继承。
           LPSECURITY_ATTRIBUTES lpThreadAttributes,//指向SECURITY_ATTRIBUTES 结构的指针,用来决定返回的线程对象能否被子进程继承,如果为NULL,则不可继承。  
           BOOL bInheritHandles,//指示新进程是否从调用进程处继承了句柄。如果参数的值为真,调用进程中的每一个可继承的打开句柄都将被子进程继承。被继承的句柄与原进程拥有完全相同的值和访问权限。
           DWORD dwCreationFlags,//指定附加的、用来控制优先类和进程的创建的标志。以下的创建标志可以以除下面列出的方式外的任何方式组合后指定。
           LPVOID lpEnvironment,//指向一个新进程的环境块。如果此参数为空,新进程使用调用进程的环境。
           LPCTSTR lpCurrentDirectory,//指向一个以NULL结尾的字符串,这个字符串用来指定子进程的工作路径。
           LPSTARTUPINFO lpStartupInfo,//指向一个用于决定新进程的主窗体如何显示的STARTUPINFO结构体。 
           LPPROCESS_INFORMATION lpProcessInformation//指向一个用来接收新进程的识别信息的PROCESS_INFORMATION结构体
   );
  1. TerminateProcess()函数原型及参数解释:

    BOOL TerminateProcess(HANDLE hProcess,UINT uExitCode)
        //hProcess可以从进程的参数lpProcessInformation.hProcess获取
    

实验步骤

  1. 创建进程

    bool CREATE(){
            si.cb = sizeof(si);
            si.wShowWindow = SW_SHOW;
            si.dwFlags = STARTF_USESHOWWINDOW;
            ::CreateProcess("D:\\Typera\\Typora\\Typora.exe",
                            NULL, NULL, NULL, false, NULL, NULL, NULL,  &si, &pi);
            return true;
        }
    
  2. 销毁进程

    bool EXIT(){
            TerminateProcess(pi.hProcess, 300);
        }
    
  3. 总代码

    class Process{
    private:
        PROCESS_INFORMATION pi;
        STARTUPINFO si;//进程启动信息
    public:
        Process(){
            memset(&si, 0 ,sizeof(STARTUPINFO));
        }
        PROCESS_INFORMATION& getpi(){
            return pi;
        }
        bool CREATE(){
            si.cb = sizeof(si);
            si.wShowWindow = SW_SHOW;
            si.dwFlags = STARTF_USESHOWWINDOW;
            ::CreateProcess("D:\\Typera\\Typora\\Typora.exe",
                            NULL, NULL, NULL, false, NULL, NULL, NULL,  &si, &pi);
            return true;
        }
        bool EXIT(){
            TerminateProcess(pi.hProcess, 300);
        }
    };
    

思考

系统是怎样创建进程的?

  1. 打开将要在进程中执行的映像文件
  2. 创建Windows执行体进程对象
  3. 创建初始线程
  4. 通知Windows子系统新进程创建了
  5. 开始执行初始线程
  6. 在新进程和线程环境中完成地址恐怖攻击初始化,然后开始到进程入口执行

可执行文件加载时进行了哪些处理?

将源代码转换为机器可认识代码的过程。编译程序读取源程序(字符流),对之进行词法和语法的分析,将高级语言指令转换为功能等效的汇编代码,再由汇编程序转换为机器语言,并且按照操作系统对可执行文件格式的要求链接生成可执行程序。具体经过以下几个处理:C源程序一>编译预处理一>编译一>优化程序一>汇编程序一>链接程序一>可执行文件

当首次调用新创建进程时,其入口在哪里?

在进程队列的ready状态下,由离自己最近的父进程执行调度,即入口在最近的父进程处。

  • 14
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
1.基本系统进程   Csrss.exe:这是子系统服务器进程,负责控制Windows创建或删除线程以及16位的虚拟DOS环境。   System Idle Process:这个进程是作为单线程运行在每个处理器上,并在系统不处理其它线程的时候分派处理器的时间。   Smss.exe:这是一个会话管理子系统,负责启动用户会话。   Services.exe:系统服务的管理工具。   Lsass.exe:本地的安全授权服务。   Explorer.exe:资源管理器。   Spoolsv.exe:管理缓冲区中的打印和传真作业。   Svchost.exe:这个进程要着重说明一下,有不少朋友都有这种错觉:若是在“任务管理器”中看到多个Svchost.exe在运行,就觉得是有病毒了。其实并不一定,系统启动的时候,Svchost.exe将检查注册表中的位置来创建需要加载的服务列表,如果多个Svchost.exe同时运行,则表明当前有多组服务处于活动状态;多个DLL文件正在调用它。   至于其它一些附加进程,大多为系统服务,是可以酌情结束运行的。由于其数量众多,我们在此也不便于一一列举。   在系统资源紧张的情况下,我们可以选择结束一些附加进程,以增加资源,起到优化系统的作用。在排除基本系统及附加进程后,新增的陌生进程就值得被大家怀疑了。 更多内容请看Windows操作系统安装、系统优化大全、系统安全设置专题,或进入讨论组讨论。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yiyiqwq

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值