其實(shí)很簡單,就是把
if(fork()==0)
{
????execve(...);
}
else
{
wait(state);
}
結(jié)構(gòu)中的else去掉就可以了
下面是一個(gè)示例
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <wait.h>
#include <errno.h>
#include <sys/stat.h>
#include <string.h>
int main(int argc,char** argv)
{
? int * status;
? int gc;
? char command[64]="./clu";
? char comarg[64]="";
? argv[1]=comarg;
? while(1)
??? {
????? if((gc=getchar())=='g')
?{
?? if(fork()==0)
???? {
?????? if(execve(command,argv,0)==-1)
??{
??? printf("process error is %s\n",strerror(errno));
??}
?????? printf("process is ok\n");
???? }
?}
????? if(gc=='k')
?{
?? printf("to be continue\n");
?}
????? if(gc=='e')
?{
?? return 1;
?}
??? }
?}
功能是這樣的,啟動(dòng)以后會(huì)從鍵盤接受字符,如果是g就運(yùn)行預(yù)先指定好的程序(在這里是一個(gè)叫clu的程序),如果是k就打印to be continue,如果是e就退出
下面是這個(gè)叫clu的程序的代碼
#include <stdio.h>
#include <time.h>
int main()
{
? long begin=0;
? long end=24000;
? long finish=0;
? long loop1,loop2;
? time_t flag;
? time_t nowtime1,nowtime2;
? if((flag=time(&nowtime1))==-1)exit(1);
? for(loop1=begin;loop1<end;loop1++)
??? {
????? for(loop2=begin;loop2<end;loop2++)
?{
?? if((loop1%2)==0)
???? {
?????? if((loop2%2)==0)
??{
??? if(finish>65535)
????? finish=0;
??? finish+=((loop1/2+loop2/2)%2)%2;
??}
???? }
?}
??? }
? if((flag=time(&nowtime2))==-1)exit(1);
? printf("%ld\n",finish);
? printf("proccess time %ldsec\n",nowtime2-nowtime1);
}
這個(gè)程序本身沒有任何意義,只是純粹的延誤一下時(shí)間,輸出一下運(yùn)行的時(shí)間,便于測試,在我的AMD2500+上,大概是5秒,你可以試試哦^_^
要測試這個(gè)程序,可以在程序運(yùn)行時(shí)輸入g,但是這個(gè)計(jì)算不會(huì)馬上結(jié)束,在屏幕還沒有輸出的時(shí)候再輸入k,就會(huì)先輸出k的內(nèi)容,后臺(tái)clu的結(jié)果出來后才輸出到屏幕,也就是clu在后臺(tái)運(yùn)行了