**1.**进程中的全局数据段、局部数据段、静态数据段分别位于哪个内存储存空间?
其中,数据段中:储存已被初始化的变量,包括全局变量和已被初始化的静态变量
未初始化数据段:储存未被初始化的静态变量,他也被称为bss段
堆:用来存放程序运行中动态分配的变量
栈:用于函数调用,保存函数的返回地址、函数的参数、函数内部定义的局部变量
****2.列举父进程与子进程属性的异同
1.子进程有他自己唯一的进程ID
2.fork的返回值不同,父进程返回子进程的ID,子进程则为0
3.不同的父进程ID。子进程的父进程ID为创建他的父进程ID
4.子进程共享父进程打开的文件描述符,但父进程对文件描述符的改变不会影响子进程中的文件描述符。
5.子进程不继承父进程设置的文件锁
6.子进程不继承父进程设置的警告
7.子进程的未决信号集被清空
3.如何创建一个后台进程?
1、调用fork函数,创建一个子进程。
2、先让父进程自然结束。
3、在子进程中调用setpgrp(),把子进程的进程组ID设为子进程的进程ID。
4、在子进程中调用setsid(),创建一个新的Session(会话),这样子进程就与当前的控制终端脱离,也接受不到当前终端的(ctrl + c)消息。
#include <iostream>
#include <unistd.h>
using namespace std;
void print()
{
int pid = getpid();
int gid = getpgid(0);
cout << "process group id = " << gid << endl;
cout << "process id = " << pid << endl;
}
int main()
{
//create a child process.
int pid = fork();
if (-1 == pid)
{
cout << "call function fork() error!" << endl;
}
else if (0 == pid) //return from child process.
{
cout << "----------in child process.----------" << endl;
print();
cout << "--------------------------------------" << endl;
//将该进程的进程组ID设置为该进程的进程ID。
setpgrp();
cout << "----------in child process. setpgrp()----------" << endl;
print();
cout << "--------------------------------------" << endl;
//创建一个新的Session,断开与控制终端的关联。也就是说Ctrl+c的触发的SIGINT信号,该进程接收不到。
setsid();
for (int i = 0; i < 5; ++i)
{
sleep(20);
cout << "----------in child process.----------" << endl;
print();
cout << "--------------------------------------" << endl;
}
}
else //return from parent process.
{
cout << "----------in parent process.----------" << endl;
print();
cout << "--------------------------------------" << endl;
}
return 0;
}