
在Linux下,子进程的创建和运行是非常方便和灵活的,但是在子进程中使用标准输出流cout输出信息相对来说有些麻烦。因为cout是一个C++的流对象,它是在C++标准库中定义的。而在Linux下很多场景中,我们都需要使用C语言进行开发,这就需要我们考虑如何在子进程中使用cout输出信息。
本文将介绍三种在Linux下在子进程中使用cout输出信息的方法。
之一种方法:使用dup2函数将cout输出流重定向到标准输出
dup2函数是一个很常用的函数,它可以把指定的文件描述符拷贝到另一个文件描述符上。在这里,我们可以使用dup2函数将子进程的标准输出流重定向到标准输出上,这样就可以在子进程中使用cout输出信息了。
下面是代码示例:
“`cpp
#include
#include
using namespace std;
int mn()
{
pid_t pid;
pid = fork();
if(pid
{
cout
}
else if(pid == 0) //子进程
{
dup2(fileno(stdout), fileno(stderr)); //将标准输出流重定向到stderr上
cout
exit(0);
}
else //父进程
{
wt(NULL);
cout
exit(0);
}
return 0;
}
“`
在上面的代码中,我们调用了dup2函数将标准输出流重定向到标准错误上,这样就可以在子进程中使用cout输出信息了,并且在父进程中输出了一条信息。
第二种方法:使用可执行文件传递数据
在Linux下,使用可执行文件执行一个指令可以通过调用系统函数system()实现。这个函数的调用格式如下:
“`cpp
int system(const char *command);
“`
其中,parameter是需要执行的可执行文件的路径及其参数,例如:
“`cpp
system(“./test abc”);
“`
这里的test是一个可执行文件的名称,abc是要传递给它的参数。
下面是代码示例:
“`cpp
#include
#include
#include
#include
using namespace std;
int mn(int argc, char *argv[])
{
pid_t pid;
pid = fork();
if(pid
{
cout
}
else if(pid == 0) //子进程
{
char* str = const_cast(“Hello World!”);
execlp(“./test”, “./test”, str, NULL);
}
else //父进程
{
wt(NULL);
cout
exit(0);
}
return 0;
}
“`
在上面的代码中,我们使用execlp函数执行了一个名为test的可执行文件,并传递了一个字符串参数”Hello World!”。在test这个可执行文件中,我们可以使用cout输出这个字符串信息。
第三种方法:使用fprintf将cout信息输出到标准错误流中
在Linux下,标准输出流和标准错误流都是向终端输出的流。在子进程中使用cout输出信息也可以重定向到标准错误流上,这样就可以避免了前面介绍的dup2函数的调用。
下面是代码示例:
“`cpp
#include
#include
#include
#include
using namespace std;
int mn()
{
pid_t pid;
pid = fork();
if(pid
{
cout
}
else if(pid == 0) //子进程
{
fprintf(stderr, “I am child process!\n”);
exit(0);
}
else //父进程
{
wt(NULL);
cout
exit(0);
}
return 0;
}
“`
在上面的代码中,我们使用fprintf函数将cout信息输出到标准错误流中,同时也在test这个可执行文件中,我们可以通过重定向标准错误流来获取这个信息。
相关问题拓展阅读:
- 创建一个子进程打开你的linux系统中的浏览器,子进程结束后输出子进程
- 在 linux中如何结束由一个父进程产生的所有子进程
- linux中,如何查看某个进程号下面有哪些子进程?
创建一个子进程打开你的linux系统中的浏览器,子进程结束后输出子进程
#include
#include
#include
#define
bufsize
int
main(void)
{
char
ch,dh,eh;
int
p;//文件描述符
pid_t
childpid;
if(pipe(p)
==
-1)/中行/创建管道戚稿
{
perror(“pipe
call”);
return
-1;
}
if((childpid
=
fork())
==
-1)//创建子进程
{
perror(“fork
call”);
return
-1;
}
if(childpid!=0)//父进程
{
close(p);//关闭读文件
do
{
ch
=
getchar();
write(p,&ch,1);//向管道写
}while(ch!=’x’);//遇到’x’则结束
}
else
if(childpid==0)//子进程
{
close(p);//关闭写文件
while(1)
{
read(p,&dh,1);//高培孝从管道读
if(dh
==
‘x’)
{
printf(“\n”);
return
0;
}
else
if(dh>=’a’&&dh=’a’&&dh
{
eh
=
(char)((int)dh
–
32);//转化改喊成大写输出
printf(“%c”,eh);
}
else
{
printf(“%c”,dh);
}
}
}
在 linux中如何结束由一个父进程产生的所有子进程
killall命令杀死同一进程组内的所有进程。它要指定要终止的进程的名称,而非PID。
父进程未结束,子进程先结束,会产生僵尸进程。
子进程在调用exit命令结束自己的生命的时候,其实它并没有真正的被销毁,而是留下一个称为僵尸进程(Zombie)的数据结构(系统调用 exit,它的作用是使进程退出,但也仅仅限于将一个正常的进程变成一个僵尸进程,并不能将其完全销毁)。
即使是root身份kill -9也不能返亩销杀死僵尸进程。补救办法是杀死僵尸进程的父进程(僵尸进程的父进程必然存在),僵尸进程成为”孤儿进程”,过继给1号进程init,init始终会负责清理僵尸进程。
僵尸进程的避免:
(1) 父进程通过wait和waitpid等函数等待子进程结束,这会导致父进程挂起。
(2) 如果父进程很忙,那么可以用signal函数为SIGCHLD安装handler,因为子进程结束后, 父
进程会收到该信号,可以在handler中调用wait回收。
(3) 如果父进耐毕程不关心子进程什么时候结束,那么可以用signal(SIGCHLD, SIG_IGN) 通知内
核,自己对子进程的结束不感兴趣,那么子进程结束后,内核会回收, 并不再给父进程发送
信号。
(4) 还有一些技巧,就是fork两次,父进程fork一个子进程,然后继续工作,子进程fork一 个孙进
程后退出,那么孙进程被init接管漏游,孙进程结束后, init会回收。不过子进程的回收 还要自己
做。
建议你使用第三种方法,父进程直接忽略子进程的结束,留给内核作回收处理。这样就不
会产生僵尸进程。
LInux 父进程液州关闭宏辩子进程蔽埋缺
采瞎辩用ps + grep + awk + pkill命令组合,可实现“结束由一个父进程产生的所有子进程”,如:
父进程名为 parent_proc,可先根据进程名称,得到进程PID
ps -ef |grep parent_proc|egrep -v grep | awk ‘{print $2}’
根据父进程PID终止所有子进程PID,保留父进程
pkill -9 -P $p_pid
完整脚本:
for p_pid in `ps -ef |grep 磨宽缺parent_proc|egrep -v grep | awk ‘{print $2}’`
do
pkill -9 -P 巧历$p_pid
done
有关各命令的详情介绍请查阅相关参考资料。
pkill -a
linux中,如何查看某个进程号下面有哪些子进程?
ps -ef |grep进程首戚名者纳陵茄答
ps -aux |grep 进程名
ps –ppid xxxx
ps -lax
top
ps -lax查看旅枣纯岩悄进程拆咐,以及父进程。找到自己需要查看的进程的pid,然后
ps –ppid ****
ps aux |grep yourjinch或者top命令
编程方面的就不懂了 不好意思
ps –ppid xxxx
linux 子进程cout的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux 子进程cout,Linux下如何在子进程中使用cout输出信息?,创建一个子进程打开你的linux系统中的浏览器,子进程结束后输出子进程,在 linux中如何结束由一个父进程产生的所有子进程,linux中,如何查看某个进程号下面有哪些子进程?的信息别忘了在本站进行查找喔。
香港服务器首选树叶云,2H2G首月10元开通。
树叶云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/199333.html<