zoukankan      html  css  js  c++  java
  • linux process management

    CREAT PROCESS


    fork()
    |
    clone(參数,决定父子函数的共享内容)
    |
    do_fork()
    |
    copy_process()
    |
    dup_task_struct()
    创建子进程的内核堆栈。复制父进程的进程描写叙述符(task_struct)
    进程描写叙述符的非常多成员被清除或者设为初值
    设置子进程的状态task_struct-->state
    设置子进程的权限task_struct-->flags
    设置子进程的进程号task_struct-->PID
    依据clone的參数,拷贝或共享: 打开的文件(task_struct-->fd),
    文件系统信息(task_struct),
    信号处理函数(task_struct-->struct signal_struct *signal;)
    进程的地址空间task_struct-->struct mm_struct *mm, *active_mm;)
    让父子进程平分剩余的时间片。
    |
    子进程被唤醒,调用exec()并运行!

    NOTE

    进程几点要注意的:
    1,进程能够运行一个或者多个程序,一个程序能够被多个进程运行。

    2,受到共享资源的约束,进程会产生约束关系,造成进程会处于不同的状态。比方等待没有一个资源如IO请求。或造成堵塞,直到资源被满足才会释放该进程,进入运行状态。

    对于时间片用完的进程会进入就绪状态。


    3,临界资源一次仅仅同意一个进程使用。
    EXIT PROCESS

    exit()
    |
    do_exit()
    |
    对task_struct的state(设为PF_EXITING)、mm(调用__exit__mm())、segment(调用sem_exit),file(__exit_files),fs(__exit_fs),signal(exit_sighand),exit_code,notify等资源进行释放。然后调用schedule()调用其它的进程。此时进程处于僵尸状态,进程描写叙述符存在于链表中,直到父进程调用wait4()。才全然释放进程。删除链表中的进程描写叙述符task_struct和共享的资源。


    版权声明:本文博客原创文章,博客,未经同意,不得转载。

  • 相关阅读:
    原型和原型链
    面向对象
    git在idea中的使用,如何构远程git方仓库
    java maven 安装
    Kafka消费者APi
    Kafka生产者APi
    kafka基本概念
    redis常用命令
    redis.conf配置文件参数说明
    Redis.RedisNativeClient的方法get_Db 没有实现
  • 原文地址:https://www.cnblogs.com/gcczhongduan/p/4748479.html
Copyright © 2011-2022 走看看