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和共享的资源。


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。