Linux下使用c++调用shell命令

1:system()

声明:

extern int system (const char *__command) __wur;
函数说明:首先会调用fork()产生子进程,由子进程执行具体的命令,调用system期间,SIGG
HID信号会被搁置,但是SIGINT和SIGQUIT则会被忽略。
对于返回值,如果system()在调用/bin/sh时失败则返回127,其他失败原因返回-

2:popen
extern FILE *popen (const char *__command, const char *__modes) __wur;

popen()也会调用fork()产生子进程,然后从子进程中调用/bin/sh -c
来执行参数command的指令。参数type可使用“r”代表读取,“w”
代表写入。依照此type值,popen()会建立管道连到子进程的标准输
出设备或标准输入设备,然后返回一个文件指针。随后进程便可利
用此文件指针来读取子进程的输出设备或是写入到子进程的标准输
入设备中。此外,所有使用文件指针(FILE*)操作的函数也都可以使
用,除了fclose()以外。
3、使用vfork()新建子进程,然后调用exec函数族
先介绍一下vfork函数,与fork函数的区别:

fork与vfork的区别
1. fork要拷贝父进程的数据段;而vfork则不需要完全拷贝父进程的数据段,在子进程没有调用exec和exit之前,子进程与父进程共享数据段
2. fork不对父子进程的执行次序进行任何限制;而在vfork调用中,子进程先运行,父进程挂起,直到子进程调用了exec或exit之后,父子进程的执行次序才不再有限制。

结束子进程不用exit(0),而使用_exit(0)。这是因为_exit(0)在结束进程时,不对标准I/O流进行任何操作。而exit(0)则会关闭进程的所有标准I/O流。

#include
main()
{
char * argv[ ]={“ls”,”-al”,”/etc/passwd”,(char*) };

if(vfork() = =0)
{
execv(“/bin/ls”,argv);
}else{
printf(“This is the parent process\n”);
}
}

4 使用exec函数群,这个比较繁琐,建议移步csdn查看

你可能感兴趣的:(linux,c++,shell,函数)