进程相关概念

      1.进程相关概念

      进程是代码的一次动态执行,担当分配系统资源的角色,进程信息是被放在一个一个数据结构中,是一个结构体task_struct

      2.进程控制块内容

                    这里写图片描述

//linux下的进程控制块
struct task_struct {volatile long state;// 说明了该进程是否可以执行,还是可中断等信息unsigned long flags;// Flage 是进程号,在调用fork()时给出int sigpending;// 进程上是否有待处理的信号 mm_segment_t addr_limit;// 进程地址空间,区分内核进程与普通进程在内存存放的位置不同0 - 0xBFFFFFFF for user - thead0 - 0xFFFFFFFF for kernel - threadvolatile long need_resched; //调度标志,表示该进程是否需要重新调度, 若非 0, 则当从内核态返回到用户态,会发生调度 int lock_depth;//锁深度 long nice; //进程的基本时间片 unsigned long policy; //进程的调度策略,有三种 实时进程:SCHED_FIFO,SCHED_RR 分时进程:SCHED_OTHER struct mm_struct mm; //进程内存管理信息 int processor; //若进程不在任何CPU上运行。cpus_runnable 的值是0,否则是1。 这个值在运行队列被锁时更新. unsigned long cpus_runnable, cpus_allowed;struct list_head run_list; //指向运行队列的指针 unsigned long sleep_time; //进程的睡眠时间 struct task_struct next_task, prev_task; //用于将系统中所有的进程连成一个双向循环链表,其根是init_task. struct mm_struct active_mm;truct list_head local_pages; //指向本地页面unsigned int allocation_order, nr_local_pages;struct linux_binfmt binfmt;// 进程所运行的可执行文件的格式int exit_code, exit_signal;int pdeath_signal;// 父进程终止是向子进程发送的信号unsigned long personality; // Linux 可以运行由其他UNIX操作系统生成的符合iBCS2标准的程序int did_exec : 1; //按POSIX要求设计的布尔量,区分进程正在执行从父进程中继承的代码,还是执行由execve装入的新程序代码 pid_t pid;// 进程标识符,用来代表一个进程pid_t pgrp; //进程组标识,表示进程所属的进程组pid_t tty_old_pgrp; //进程控制终端所在的组标识pid_t session; //进程的会话标识pid_t tgid;int leader; //标志,表示进程是否为会话主管struct task_structp_opptr p_pptr, p_cptr, p_ysptr, p_osptr;struct list_head thread_group;// 线程链表struct task_struct pidhash_next; //用于将进程链入HASH表pidhash struct task_struct pidhash_pprev;wait_queue_head_t wait_chldexit; //供wait4()使用struct completion vfork_done; //供vfork() 使用 unsigned long rt_priority; // 实时优先级,用它计算实时进程调度时的weight值,unsigned long it_real_value, it_prof_value, it_virt_value;unsigned long it_real_incr, it_prof_incr, it_virt_value;struct timer_list real_timer;//指向实时定时器的指针struct tms times; //记录进程消耗的时间,unsigned long start_time;//进程创建的时间long per_cpu_utime[NR_CPUS], per_cpu_stime[NR_CPUS];//记录进程在每个CPU上所消耗的用户态时间和核心态时间mm fault and swap info : this can arguably be seen as eithermm - specific or thread - specific//内存缺页和交换信息://min_flt, maj_flt累计进程的次缺页数(Copy on Write页和匿名页)和主缺页数(从映射文件或交换设备读入的页面数);//nswap记录进程累计换出的页面数,即写到交换设备上的页面数。//cmin_flt, cmaj_flt, cnswap记录本进程为祖先的所有子孙进程的累计次缺页数,主缺页数和换出页面数。在父进程//回收终止的子进程时,父进程会将子进程的这些信息累计到自己结构的这些域中unsigned long min_flt, maj_flt, nswap, cmin_flt, cmaj_flt, cnswap;int swappable : 1; //表示进程的虚拟地址空间是否允许换出process credentials ///进程认证信息//uid,gid为运行该进程的用户的用户标识符和组标识符,通常是进程创建者的uid,gid //euid,egid为有效uid,gid//fsuid,fsgid为文件系统uid,gid,这两个ID号通常与有效uid,gid相等,在检查对于文件系统的访问权限时使用他们。//suid,sgid为备份uid,giduid_t uid, euid, suid, fsuid;gid_t gid, egid, sgid, fsgid;int ngroups; //记录进程在多少个用户组中gid_t groups[NGROUPS]; //记录进程所在的组kernel_cap_t cap_effective, cap_inheritable,cap_permitted;//进程的权能,分别是有效位集合,继承位集合,允许位集合int keep_capabilities : 1;struct user_struct user;limitsstruct rlimit rlim[RLIM_NLIMITS]; //与进程相关的资源限制信息unsigned short used_math; //是否使用FPUchar comm[16]; //进程正在运行的可执行文件名file system info //文件系统信息int link_count, total_link_count;struct tty_struct tty; NULL if no tty 进程所在的控制终端,如果不需要控制终端,则该指针为空unsigned int locks; How many file locks are being heldipc stuff //进程间通信信息struct sem_undo semundo; //进程在信号灯上的所有undo操作struct sem_queue semsleeping; //当进程因为信号灯操作而挂起时,他在该队列中记录等待的操作CPU - specific state of this task //进程的CPU状态,切换时,要保存到停止进程的task_struct中struct thread_struct thread;filesystem information; 文件系统信息struct fs_struct fs;open file information //打开文件信息struct files_struct files;signal handlers //信号处理函数spinlock_t sigmask_lock;Protects signal and blockedstruct signal_struct sig; //信号处理函数,sigset_t blocked; //进程当前要阻塞的信号,每个信号对应一位struct sigpending pending; //进程上是否有待处理的信号
}
      3.进程状态

      R 运行状态,S 睡眠状态, D 状态深度睡眠状态,(在该状态下的进程不能被其他进程唤醒,只有自己可以唤醒自己),T 停止状态, t 追加状态, X 死亡状态, Z 僵尸状态

      4.僵尸进程

      定义:;所谓僵尸进程就是进程处于一个僵死的状态,即进程已经退出,但其父进程没有得到子进程的退出信息,此时的进程就会成为一个僵尸进程。
      来看一段代码

#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>int main()
{pid_t id;id = fork();if(id < 0){perror("fork");exit(0);}else if(id == 0){printf("I am child\n");sleep(1);}else{printf("I am father\n");sleep(15);}return;
}

这里写图片描述
      于是看到了系统中出现了一个僵尸进程。在此必须注意,僵尸进程的父进程如果一直不去读取该进程的信息,则这个进程将会一直处于将是状态,并且该进程的PCB也将一直被维持,那么就会造成内从泄露。

      5.孤儿进程

        孤儿进程就是父进程先于子进程退出,此时的子进程就会变成孤儿进程,那是不是就是说该进程的信息就没人来读取吗?答案是否定的。此时的子进程会被1号init进程领养,于是该子进程就会变成孤儿进程。

#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>int main()
{pid_t id;id = fork();if(id < 0){perror("fork");exit(0);}else if(id == 0){printf("I am child\n");sleep(1);}else{printf("I am father\n");sleep(15);}return;
}

          这里写图片描述
        监视可以看到并没有僵尸状态,则说明子进程退出时的信息被其他进程读取,进而也说明进程被领养。

      6.查看系统进程

        查看系统进程可以用ps,或者top命令来查看
        这里写图片描述
        其中 PRI 是优先级,数字越小优先级越高,而 nice 是用来修改 PRI 的 PRI(new) = PRI(old) + nice, nice 的取值范围是 -20 到 19, 创建进程时 PRI 默认是80, 而 nice 默认为 0。
        进城之间具有竞争性, 系统进程数目众多, 而 CPU 的资源有限,因此为了能够高效完成任务,合理竞争相关资源,进程之间就需要有一个优先级,确保CPU正常工作;同时进程在运行期间独享各自资源,互不干扰,因此进程是具有独立性的;在多个CPU 的状况下, 进程之间可以同时工作,因此进程具有独立性;当只有一个CPU时,为了让每个进程得以运行,CPU采用进程切换的方式,以确保在一段时间里每一个进程都可以得以运行,因此进程具有并发性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/384123.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SPOJ - QTREE3Query on a tree again!——树链剖分

【题目描述】 SPOJ - QTREE3Query on a tree again! 【题目分析】 题目要求是输出从111到xxx的路径上遇到的第一个黑色的点。我们可以用树链剖分&#xff08;不了解的同学请出门左拐&#xff0c;详见树链剖分入门&#xff09; 我们用线段树维护每个区间第一次遇到黑点的位置&a…

C++中的函数指针和函数对象总结

http://www.cnblogs.com/lvpengms/archive/2011/02/21/1960078.html 篇一、函数指针 函数指针&#xff1a;是指向函数的指针变量&#xff0c;在C编译时&#xff0c;每一个函数都有一个入口地址&#xff0c;那么这个指向这个函数的函数指针便指向这个地址。 函数指针的用途是很…

开发工具

1.编辑器 &#xff08;1&#xff09;vim     vim是从vi发展出来的一个文本编辑器。代码补完、编译错误跳转等方便编程的功能特别丰富&#xff0c;在程序员中被广泛使用。 &#xff08;2&#xff09;sed     sed是一种流编辑器&#xff0c;它一次处理一行内容。处理时…

c++ 智能指针用法详解

http://www.cnblogs.com/TenosDoIt/p/3456704.html 本文介绍c里面的四个智能指针: auto_ptr, shared_ptr, weak_ptr, unique_ptr 其中后三个是c11支持&#xff0c;并且第一个已经被c11弃用。 为什么要使用智能指针&#xff1a;我们知道c的内存管理是让很多人头疼的事&#xff0…

CodeForces - 786BLegacy——线段树建图+最短路

【题目描述】 CodeForces - 786BLegacy 【题目分析】 题目大概意思就是有三种操作&#xff1a; 从某个点到另一个点从某个点到另一个区间从某个区间到另一个点 然后询问从其中一个点到其他所有点的距离——这很显然是一个求单源最短路径的。我们简单的想法显然是建一个图&a…

自主编写shell

1.替换原理 用fork创建子进程后执行的是和父进程相同的程序&#xff08;但有可能执行不同的代码分支&#xff09;&#xff0c;子进程往往要调用一种exec函数以执行例外一个程序。当进程调用一种exec函数时&#xff0c;该进程的用户空间代码和数据完全被新程序替换&#xff0c;从…

HYSBZ - 2243染色——树链剖分+线段树建树技巧

【题目描述】 HYSBZ - 2243染色 【题目分析】 我一直没有看清楚题&#xff0c;以为求的是路径上出现颜色的种类&#xff0c;然后就写了一个区间染色的线段树进行维护&#xff0c;过样例的时候才发现题读错了&#xff0c;人家要求的是路径上出现的颜色段&#xff0c;所以颜色的…

打动态库和静态库

一.动态库和静态库的定义 1.静态库     程序在编译链接时把库的代码链接到可执行文件中。程序运行时就不再需要静态库 2.动态库     程序在运行的时候才去链接动态库的代码&#xff0c;多个程序 共享使用代码 3.动态链接     在执行文件之前&#xff0c;外部…

HYSBZ - 2157树链剖分

【题目描述】 HYSBZ - 2157树链剖分 【题目分析】 这道题给出的是边权而不是点权&#xff0c;但是我们分析这个树就会发现每个节点都只有一个父亲&#xff0c;也就是每条边的边权都可以存放在儿子节点上&#xff0c;然后在遍历路径的时候我们在从前往后遍历&#xff0c;但是注…

C++11中的右值引用

http://www.cnblogs.com/yanqi0124/p/4723698.html 在C98中有左值和右值的概念&#xff0c;不过这两个概念对于很多程序员并不关心&#xff0c;因为不知道这两个概念照样可以写出好程序。在C11中对右值的概念进行了增强&#xff0c;我个人理解这部分内容是C11引入的特性中最难以…

BZOJ2115XOR——线性基

【题目描述】 BZOJ2115XOR——线性基 【题目分析】 这道题看完以后很懵逼&#xff0c;人家要是走的很复杂呢&#xff1f;各种绕来绕去怎么办&#xff1f; 首先我们应该注意到一个很明显的道理&#xff1a;重复的路径会和自身抵消&#xff0c;所以我们大可以随便跑&#xff0c;…

单链表的相关操作

1.冒泡排序对单链表进行排序 void LinkListBubbleSort(LinkNode* head) {if(head NULL){ return;//空链表} if(head -> next NULL){ return;//只有一个结点} LinkNode* cur head;//趟数LinkNode* tail NULL;//尾指针LinkNode* tmp head;//次数for(; cur -…

socket网络编程--epoll小结

http://www.cnblogs.com/wunaozai/p/3895860.html 以前使用的用于I/O多路复用为了方便就使用select函数&#xff0c;但select这个函数是有缺陷的。因为它所支持的并发连接数是有限的(一般小于1024)&#xff0c;因为用户处理的数组是使用硬编码的。这个最大值为FD_SETSIZE&#…

进程间通信(匿名管道)

1.进程通信的目的 (1) 数据传输: 一个进程需要将它的数据传输给另一个进程     (2) 资源共享: 多个进程之间共享同样的资源     (3) 通知事件: 一个进程需要向另一个或一组进程发送消息, 通知它们发生了什么事情 2.管道 管道是一种进程之间通信的一种方式, 我们把从…

单例模式及C++实现代码

http://www.cnblogs.com/cxjchen/p/3148582.html 单例模式 单例模式&#xff0c;可以说设计模式中最常应用的一种模式了&#xff0c;据说也是面试官最喜欢的题目。但是如果没有学过设计模式的人&#xff0c;可能不会想到要去应用单例模式&#xff0c;面对单例模式适用的情况&am…

命名管道

1.命名管道的创建 (1) 通过命令创建 mkfifo filename (2)在程序中创建 int mkfifo(const char* filename, mode_t mode); 2. 命名管道和匿名管道的区别 (1)匿名管道由pipe函数创建并且打开     (2)命名管道有mkfifo函数创建由open函数打开     (3) fifo 之间的两…

HYSBZ - 1101——莫比乌斯反演

【题目描述】 HYSBZ - 1101 【题目分析】 昨天测试出了一道差不多的题目&#xff0c;我只能想到暴力&#xff0c;各种优化&#xff0c;最后都是运行了好久TLE&#xff0c;最后才知道要用到莫比乌斯反演&#xff0c;就想着今天研究一下&#xff0c;得出的结论就是&#xff0c;我…

Linux下I/O多路转接之select --fd_set

http://blog.csdn.net/li_ning_/article/details/52165993 fd_set 你终于还是来了&#xff0c;能看到这个标题进来的&#xff0c;我想&#xff0c;你一定是和我遇到了一样的问题&#xff0c;一样的疑惑&#xff0c;接下来几个小时&#xff0c;我一定竭尽全力&#xff0c;写出我…

I/O多路转接之poll 函数

http://blog.csdn.net/li_ning_/article/details/52167224 poll 一、poll()函数&#xff1a; 这个函数是某些Unix系统提供的用于执行与select()函数同等功能的函数&#xff0c;自认为poll和select大同小异&#xff0c;下面是这个函数的声明&#xff1a; [cpp] view plaincopy …

链表相关笔试面试题

1.判断两个链表是否相交 两个链表是否相交可分为以下几种情况     &#xff08;1&#xff09;两个链表都不带环&#xff0c;此时两个链表所对应的最后一个节点是相等的     &#xff08;2&#xff09;两个链表一个带环&#xff0c;一个不带环&#xff0c;两个链表一定…