[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)
解决方案 »
- C#模拟鼠标左键点击
- 将两个整数连接为一个整数
- VB和C#取数据库字段值问题
- c++ 写的dll 导出 函数 xx_send(char* buf,int size),在 c#中怎么用
- 如何实现这个泛型方法?
- 有谁会做数据导航条啊?我就是不会写“增加记录”这个按钮的事件代码了!!
- C#删除Excel行
- 100分,在线求解,如何在多线程中,循环间隔一段时间执行操作
- C#访问Access的问题,就90分全部送出!
- 如何实现水晶报表的注册?
- 关于C#在WINFORM里操作EXCEL的问题,我弄了一天都没弄出来,着急......
- 现在有一个完整的C#源程序网站,里的源程序全部可以看见,也VS2003.NET的,但里面没有解决方案和项目文件,我如何才能有设计视图呢?
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
);