[DllImport("kernel32.dll", SetLastError=true)] static extern int OpenProcess ( int dwDesiredAccess, int bInheritHandle, int dwProcessId)[DllImport("kernel32.dll", SetLastError=true)] static extern int CreateProcessA ( string lpApplicationName, string lpCommandLine, ref SECURITY_ATTRIBUTES lpProcessAttributes, ref SECURITY_ATTRIBUTES lpThreadAttributes, int bInheritHandles, int dwCreationFlags, ref object lpEnvironment, string lpCurrentDriectory, ref STARTUPINFO lpStartupInfo, ref PROCESS_INFORMATION lpProcessInformation)[DllImport("kernel32.dll", SetLastError=true)] static extern int CloseHandle ( int hObject)

解决方案 »

  1.   

    [DllImport("kernel32.dll", EntryPoint="OpenProcess")]
    public static extern int OpenProcess (
    int dwDesiredAccess,
    int bInheritHandle,
    int dwProcessId
    );
    [DllImport("kernel32.dll", EntryPoint="CreateProcess")]
    public static extern int CreateProcess (
    string lpApplicationName,
    string lpCommandLine,
    ref SECURITY_ATTRIBUTES lpProcessAttributes,
    ref SECURITY_ATTRIBUTES lpThreadAttributes,
    int bInheritHandles,
    int dwCreationFlags,
    ref int lpEnvironment,
    string lpCurrentDriectory,
    ref STARTUPINFO lpStartupInfo,
    ref PROCESS_INFORMATION lpProcessInformation
    );
      lpApplicationName -  String,要执行的应用程序的名字。可设为vbNullString;在这种情况下,应用程序的名字应在lpCommandLine参数的起始处出现  lpCommandLine --  String,要执行的命令行。可用GetCommandLine函数取得一个进程使用的命令行。Windows会尽可能地根据下述搜索顺序来查找执行文件:
        (1)包含了父进程执行文件的目录
        (2)父进程当前的目录
        (3)由GetSystemDirectory返回的系统目录
        (4)仅适于windows NT:16位系统目录
        (5)由GetWindowDirectory返回的Windows目录
        (6)由PATH环境变量指定的目录  lpProcessAttributes -  SECURITY_ATTRIBUTES,指定一个SECURITY_ATTRIBUTES结构,或传递零值(将参数声明为ByVal
      As Long,并传递零值)——表示采用不允许继承的默认描述符。该参数定义了进程的安全特性  lpThreadAttributes -  SECURITY_ATTRIBUTES,指定一个SECURITY_ATTRIBUTES结构,或传递零值(将参数声明为ByVal
      As Long,并传递零值)——表示采用不允许继承的默认描述符。该参数定义了进程之主线程的安全特性  bInheritHandles -  Long,TRUE表示允许当前进程中的所有句柄都由新建的子进程继承  dwCreationFlags -  Long,来自API32.TXT文件的一个或多个下述常数之一,它们都带有前缀CREATE_。下面这些用于VB程序员:
      CREATE_SEPARATE_WOW_VDM(仅适用于NT)
      启动一个16位的Windows应用程序时,强迫它在自己的内存空间运行
      CREATE_SHARED_WOW_VDM(仅适用于NT)
      启动一个16位的Windows应用程序时,强迫它在共享的16位虚拟机(VM)内运行
      CREATE_SUSPENDED
      立即挂起新进程。除非调用了ResumeThread函数函数,否则它不会恢复运行
      也可能是下述常数之一,用于指定优先级
      IDLE_PRIORITY_CLASS
      新进程应该有非常低的优先级——只有在系统空闲的时候才能运行。基本值是4
      HIGH_PRIORITY_CLASS
      新进程有非常高的优先级,它优先于大多数应用程序。基本值是13。注意尽量避免采用这个优先级
      NORMAL_PRIORITY_CLASS
      标准优先级。如进程位于前台,则基本值是9;如在后台,则优先值是7
      不要在VB中使用REALTIME_PRIORITY_CLASS  lpEnvironment --  Any,指向一个环境块的指针(环境缓冲区的头一个字符,或者环境块的地址)  lpCurrentDriectory -  String,新进程的当前目录路径。调用函数的时候,可用vbNullString指定当前目录  lpStartupInfo --  STARTUPINFO,指定一个STARTUPINFO结构,其中包含了创建进程时使用的附加信息  lpProcessInformation -  PROCESS_INFORMATION,该结构用于容纳新进程的进程和线程标识符。大多数情况下,一旦这个函数返回,父应用程序都会关闭两个句柄。[DllImport("kernel32.dll", EntryPoint="CloseHandle")]
    public static extern int CloseHandle (
    int hObject
    );