system()只是做一个调用其他程序的工作,只要调用成功就返回0,不成功就返回-1。
它不能得到被调用的程序的执行结果。
要得到其他程序的执行的结果,要用spawn***()这个家族的函数。
Linux和Windows中system的不同之处在于:如果子程序调用成功,但执行失败时,Linux下的system函数返回该子进程的返回值,而Windows下的system函数返回0,不是返回该子进程返回值,也无法得到该子进程返回值,所以用CreateProcess函数和GetExitCodeProcess函数代替。
改造方法如下:
1) 使用SetStdHandle函数改变STD_OUTPUT_HANDLE的值(把标准输出重定向到指定的文件)。
2) 使用GetStdHandle函数得到STD_OUTPUT_HANDLE的句柄(用来指定子进程的输出位置)。
3) 设置STARTUPINFO结构(以siStartInfo为例),siStartInfo.dwFlags|=
4) 执行CreateProcess函数,创建子进程。
5) 执行WaitForSingleObject函数,等待子进程执行结束。(注:以INFINITE为第2个参数)
6) 执行GetExitCodeProcess函数,得到子进程的退出代码。
如果你要判断system是否执行成功,下面是一种方法:
system("commond","arg",.....)
system()只是做一个调用其他程序的工作,只要调用成功就返回0,不成功就返回-1。
它不能得到被调用的程序的执行结果。
要得到其他程序的执行的结果,要用spawn***()这个家族的函数。
Linux和Windows中system的不同之处在于:如果子程序调用成功,但执行失败时,Linux下的system函数返回该子进程的返回值,而Windows下的system函数返回0,不是返回该子进程返回值,也无法得到该子进程返回值,所以用CreateProcess函数和GetExitCodeProcess函数代替。
改造方法如下:
1) 使用SetStdHandle函数改变STD_OUTPUT_HANDLE的值(把标准输出重定向到指定的文件)。
2) 使用GetStdHandle函数得到STD_OUTPUT_HANDLE的句柄(用来指定子进程的输出位置)。
3) 设置STARTUPINFO结构(以siStartInfo为例),siStartInfo.dwFlags|=
4) 执行CreateProcess函数,创建子进程。
5) 执行WaitForSingleObject函数,等待子进程执行结束。(注:以INFINITE为第2个参数)
6) 执行GetExitCodeProcess函数,得到子进程的退出代码。
如果你要判断system是否执行成功,下面是一种方法:
system("commond","arg",.....)