一、Windows进程

  1、进程

   进程是一种容器,包含了应用程序实例的各种资源。

  2、Windows进程的一些特点

   2.1、进程中包含了执行代码等资源

   2.2、进程都具有私有的地址空间

   2.3、每个进程都有一个ID,标识进程

   2.4、每个进程都有自己的安全属性

     2.5、至少要包含一个可以执行的线程

二、进程的环境

  1、环境信息的获取

   LPVOID GetEnvironmentStrings(VOID);    //返回值是获取到的所有环境信息

  2、释放获取到的所有环境信息

   BOOL FreeEnvironmentStrings(LPSTR lpszEnvironmentBlock);

   例如:LPSTR pszEnv = ( LPSTR )GetEnvironmentStrings( );

      FreeEnvironmentStrings( pszEnv );

  3、环境变量的获取和设置

   获取:DWORD GetEnvironmentVariable(LPCTSTR lpName,      //变量名称

                       LPTSTR lpBuffer,       //数据BUFF

                       DWORD nSize         //BUFF的长度

                       );               //返回值是获取到的字符串的长度

    设置:BOOL SetEnvironmentVariable(LPCTSTR lpName,       //变量名称

                      LPCTSTR lpValue        //变量的值

                     );


三、进程的信息

  1、进程ID和句柄

    GetCurrentProcessId    获取进程的ID

    GetCurrentProcess       获取进程的句柄,返回值为-1,是当前进程的伪句柄,如果想获得当前进程的实际句柄,需要使用OpenProcess函数

    例如: //获取进程ID

       DWORD nID = GetCurrentProcessId( );
         //获取进程句柄(-1,伪句柄)
       HANDLE hProc = GetCurrentProcess( );

         //根据进程ID获取进程实际句柄

       hProc = OpenProcess( PROCESS_ALL_ACCESS, FALSE, nID );

  2、打开进程

    通过使用进程ID得到进程句柄

    HANDLE OpenProcess(DWORD dwDesireAccess,        //访问模式

                BOOL bInheritHandle,          //继承标识

                DWORD dwProcessId          //进程ID

               );                      //返回进程的句柄

  3、获取进程的所使用的所有模块(EXE或DLL)

    BOOL EnumProcessModules(HANDLE hProcess,        //进程句柄

                   HMODULE* lphModule        //模块的数组

                   DWORD cb,               //数组的长度

                   LPDWORD lpcbNeeded      //获取到数据的字节数

                  );

    

四 进程的使用
  1 创建进程

   CreateProcess 执行一个EXE可执行文件.创建一个进程以及它的主线程.
   BOOL CreateProcess( LPCTSTR lpApplicationName,              //应用程序路径名
              LPTSTR lpCommandLine,                  //命令行
              LPSECURITY_ATTRIBUTES lpProcessAttributes,      //进程安全属性
              LPSECURITY_ATTRIBUTES lpThreadAttributes,       //线程安全属性
              BOOL bInheritHandles,                  //句柄继承标识
              DWORD dwCreationFlags,                 //创建标识
              LPVOID lpEnvironment,                   //环境块
              LPCTSTR lpCurrentDirectory,               //当前目录
              LPSTARTUPINFO lpStartupInfo,              //启动参数  
              LPPROCESS_INFORMATION lpProcessInformation       //进程信息
              );
   当进程创建成功,可以从进程信息中获取创建好的进程句柄\ID等.

  2 打开进程
   OpenProcess
  3 结束进程
   BOOL TerminateProcess( HANDLE hProcess,                 //进程句柄
                UINT uExitCode                   //结束代码

                );                          //返回值非零表示成功,0表示失败
  4 等候进程结束
   DWORD WaitForSingleObject( HANDLE hHandle,               //等候的句柄
                   DWORD dwMilliseconds             //等候的时间,毫秒

                  );
   阻塞函数,当运行时,会在等候的时间的时间内,等待句柄的信号.

Windows进程的更多相关文章

  1. windows进程/线程创建过程 --- windows操作系统学习

    有了之前的对进程和线程对象的学习的铺垫后,我们现在可以开始学习windows下的进程创建过程了,我将尝试着从源代码的层次来分析在windows下创建一个进程都要涉及到哪些步骤,都要涉及到哪些数据结构. ...

  2. windows进程函数试炼

    实践一下windows进程相关函数: 代码如下: // test__getinformation.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h&quo ...

  3. 使用WMI控制Windows进程 和服务

    1.使用WMI控制Windows进程 本文主要介绍两种WMI的进行操作:检查进程是否存在.创建新进行 代码如下: using System; using System.Collections.Gene ...

  4. 走进windows编程的世界-----windows进程

    Windows进程  1 Windows进程    进程是一个容器,包括了一个应用程序实例的各种资源.Windows多任务的操作系统,因此能够同一时候运行多个进程.      2 Windows进程的 ...

  5. Windows进程单实例运行

    场景         Windows进程单实例运行,如果有进程没有退出,继续等待,直到进程完全退出,才会进入下一个实例 HANDLE pHandle = NULL; do  {  pHandle = ...

  6. Windows进程间共享内存通信实例

    Windows进程间共享内存通信实例 抄抄补补整出来 采用内存映射文件实现WIN32进程间的通讯:Windows中的内存映射文件的机制为我们高效地操作文件提供了一种途径,它允许我们在WIN32进程中保 ...

  7. 如何使用fiddller跟踪windows进程发送的请求20140911

    总结点:如何使用fiddller跟踪windows进程发送的请求 案例如下: 需求:运维工具提出需求,对每个插件的配置文件,同步到运维中心时先加密,然后传输到运维中心解密,存储到数据库 测试分析:这个 ...

  8. windows 进程监控 Procmon.exe

    windows 进程监控 Procmon.exe window下一个程序打开太慢,可以用此程序监控.在哪一步慢了,读取文件还是注册表. ProcessMonitor3.2 Process Monito ...

  9. 查看windows进程,并删除

    1. 通过[任务管理器]可以查看windows进程. 有些进程不在[任务管理器]中. 2. 通过tasklist命令查看进程. 杀掉进程: epmd 进程,在停止.卸载后rabbitmq服务还在. 通 ...

随机推荐

  1. php strtotime函数服务器和本地不相同

    遇到过一种情况strtotime 在本地和服务器不相同 服务器返回的是-1 strtotime($sa_sagyo_ymd."23:59:59") 如果这样用不了,就只能换一种写法 ...

  2. WisDom.Net 框架设计(四) 用户安全

    WisDom.Net  ----用户安全 1.用户单机登录 正如其名这里要求其实就是显示用户只能在一台电脑上登录.防止多处登录,这里简单的说一下实现原理,我们在这里使用session +cookie ...

  3. Android EditText的输入监听,输入字符的动态获取

    http://itindex.net/detail/38974-android-edittext-%E7%9B%91%E5%90%AC 有时候我们可能会用到时时的监听EditText输入字符的时时监听 ...

  4. 设计webapp的新思路

    一般设计移动应用有3中方式:原生.脚本.混合:今天我们用另一种方式实现. 我叫它:响应式网页webApp 一.具体构架思路是这样的: 客户端:Android手机 Android手机中有控件WebVie ...

  5. 修改PYTHONPATH的一种方法(在Window平台和Ubuntu下都有效)

    1.显示PYTHONPATH 2.修改PYTHONPATH 通过PYTHONPATH 中的任何 .pth 文件来添加pythonpath.比如我想添加/home/aa这个路径到pythonpath里, ...

  6. CoreAnimation

    CoreAnimation 1.CABasicAnimation // position CABasicAnimation *ba = [CABasicAnimation animationWithK ...

  7. WF学习笔记(三)

    Collection 集合 -AddtoCollection<T> 添加项到集合 :[AddtoCollection]可以将一个项添加到[Collection]集合中 ,[Item]属性用 ...

  8. [转] 小tip: 使用CSS将图片转换成黑白(灰色、置灰) ---张鑫旭

    by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=2547 //zxx: ...

  9. C#让程序自动在管理员权限下运行

    windows 7和vista提高的系统的安全性,同时需要明确指定“以管理员身份运行”才可赋予被运行软件比较高级的权限,比如访问注册表等.否则,当以普通身份运行的程序需要访问较高级的系统资源时,将会抛 ...

  10. sourceInsight的技巧

    在用sourceInsight看代码...在这里积累技巧,慢慢积累吧 1.如何高亮显示所有要搜的东西,例如 1.aaaaaa 2. bbbbbbbbaaaaaaa 3. ccccccc 4. aaaa ...