Linux 多进程

目录

0x01 linux中特殊的进程

0x02 进程的标识

0x03 创建子进程


0x01 linux中特殊的进程

  1. 0号进程:idle进程,系统启动加载的进程
  2. 1号进程:systemd进程,系统初始化,是所有进程的祖先进程 init
  3. 2号进程:kthreadd进程,负责内核中所有进程的调度和管理

0x02 进程的标识

  • 每个进程都会有一个非负整数来标识进程,pid
  • 查看进程的命令 ps -ef | grep yourprocessname

Linux 多进程_第1张图片

从左到右依次是:启动进程的用户 进程的id标识 父进程的id cpu占用率 开始时间 启动设备 运行总时间 启动时执行的命令

# 使用getpid(void)可以获取进程的id
#include
#include
#include
#include

int main(){
    
    printf("进程的id=%d",getpid());
    printf("进程的父进程id=%d",getppid());

    sleep(10);
	return 0;
}

0x03 创建子进程

  • 使用fork函数可以创建新的进程
  • 在子进程调用fork函数创建进程会返回0,在父进程中使用fork函数会返回进程的ID
  • 子进程是父进程的副本
  • 子进程获得了父进程的数据空间,堆和栈的副本,不是共享,子进程改变数据,不会影响父进程变量的数据
  • 如果父进程先退出,子进程会成为孤儿进程,1号进程会管理孤儿进程,对子进程的状态进行收集工作
  • 如果子进程先退出,内核会向父进程发送一个SIGCHLD的信号,如果父进程不处理这个信号,子进程会成为僵尸进程
#include
#include
#include
#include
#include
#include

#include

void func(int sig){
	 int state;
     wait(&state);
}
int main(){
    // 1忽略子进程的sigchld
    // signal(SIGCHLD,SIG_IGN);
    // 3使用函数处理信号
    signal(SIGCHLD,func);
    File* file=fpopen("/tmp/tmp.txt","w+");
    fprintf(file,"this is a test\n
    fflush(file);
	printf("进程的id=%d",getpid());
    sleep(10);
	printf("进程的id=%d",getpid());
    int pid=fork();
    printf("fork出的id为%d",pid);
    sleep(1);
    if(pid==0)
    {
        printf("子进程的id为%d",getpid());
        printf("子进程的父进程id为%d",getppid
        //子进程的逻辑代码
   		fprintf(fp,"子进程 this is a test\n");
    }
    if(pid>0)
    {
		printf("父进程的id为%d",getpid());
        printf("父进程的父进程id为%d",getppid());
        //父进程的逻辑代码
    	fprintf(fp," 父进程 this is a test\n");
        //2 等待子进程退出的代码 使用wait方式阻塞等待子进程退出
        // int state;
        // wait(&state);
    }
	printf("进程的id=%d",getpid());
    sleep(30);
	printf("进程的id=%d",getpid());

    fclose(file);
}

你可能感兴趣的:(linux,服务器,网络)