进程的状态位掩码

每个进程有两个独立的状态标志:

              task->state:是关系进程的 runnability;

              task->exit_state:是关于 task exiting;


#define TASK_RUNNING        0

#define TASK_INTERRUPTIBLE  1


#define TASK_UNITERRUPTIBLE 2

#define __TASK_STOPPED      4

#define __TASK_TRACED       8

/* in task->exit_state*/


#define EXIT_ZOMBIE         16

#define EXIT_DEAD           32

 

/*in task->state*/


#define TASK_DEAD           64

#define TASK_WAKEKILL       128

#define TASK_WAKING         256

set_task_state()函数中用到的符号常量的宏定义:

#define TASK_KILLABLE (TASK_WAKEKILL | TASK_UNINTERRUPTIBLE)


#define TASK_STOPPED  (TASK_WAKEKILL | __TASK_STOPPED)


#define TASK_TRACED   (TASK_WAKEKILL | __TASK_TRACED)


wake_up()函数中用到的符号常量的宏定义:

#define TASK_NORMAL  (TASK_INTERRUPTIBLE | TASK_UNITERRUPTIBLE)

#define TASK_ALL     (TASK_NORMAL | __TASK_STOPPED | __TASK_TRACED)

get_task_state()函数中用到的符号常量的宏定义:

#define TASK_REPORT (TASK_RUNNING | TASK_INTERRUPTIBLE \

                      | TASK_UNINTERRUPTIBLE | __TASK_STOPPED\

                      | __TASK_TRACED)

set_task_state()方法的实现:


   #define set_task_state(task, state_value) \

         set_mb((task)->state, (state_value))

    set_mb()函数保证了指令的执行顺序;

   #define __set_task_state(task, state_value)  \

          do{ (task)->state = (state_value );}while(0)



set_current_stat()方法的实现:

    #define __set_current_state(state_value) \

       do{ current->state = (state_value);}while(0)

    #define set_current_state(state_value) \

       set_mb(current->state, (state_value))


时间: 2024-08-27 20:27:30

进程的状态位掩码的相关文章

Java位运算在程序设计中的使用:位掩码(BitMask)

在Java中,位运算符有很多,例如与(&).非(~).或(|).异或(^).移位(<<和>>)等.这些运算符在日常编码中很少会用到. 在下面的一个例子中,会用到位掩码(BitMask),其中包含大量的位运算.不只是在Java中,其他编写语言中也是可以使用的. 例如,在一个系统中,用户一般有查询(Select).新增(Insert).修改(Update).删除(Selete)四种权限,四种权限有多种组合方式,也就是有16中不同的权限状态(2的4次方). 一般情况下会想到用四个

进程的状态

三态模型:在多道程序系统中,进程在处理器上交替运行,状态也不断地发生变化.进程一般有3种基本状态:运行.就绪和阻塞. (1)运行:当一个进程在处理机上运行时,则称该进程处于运行状态.处于此状态的进程的数目小于等于处理器的数目,对于单处理机系统,处于运行状态的进程只有一个. 在没有其他进程可以执行时(如所有进程都在阻塞状态),通常会自动执行系统的空闲进程. (2)就绪:当一个进程获得了除处理机以外的一切所需资源,一旦得到处理机即可运行,则称此进程处于就绪状态.就绪进程可以按多个优先级来划分队列.

进程(三)—— 进程的状态

进程的状态 概要 进程创建 进程执行 进程等待 进程抢占 进程唤醒(就绪) 进程结束 进程创建 引起进程创建的情况 系统初始化时 用户请求创建一个新进程 正在运行的进程 执行了创建进程的系统调用 进程执行 内核选择一个就绪的进程,让它占用处理机并执行 如何执行?==> CPU调度再讲 ! 进程等待 进程进入等待(阻塞)的情况: 请求并等待系统服务,无法马上完成 启动某种操作,无法马上完成 需要的数据 没有到达 只有进程自身才能知道 何时需要 等待某种事件的 发生 进程抢占 进程会被抢占的情况 高

使用一个整数字段保存多个状态位数据

如今,各种大小网站经常搞各种推广优惠活动,吸引新用户,回馈老用户.如何方便快捷地记录和查询用户参与某项活动的数据是开发人员必须面对的问题. 方法一:记录用户参与活动数据到记录详情表中,查询该表一定可以获得用户的参与状态. 方法一缺点:需要单独执行一次查询操作,如果参与记录表数据量大,查询效率又是个问题. 方法二:在用户基本信息表中添加状态位字段,用户参与活动成功后,更新状态位字段,查询参与状态时直接读取基本信息中的相应字段. 方法二缺点:活动数量增加时,状态位字段必须相应增加,表中字段过多不是什

(转)进程的状态

转自:http://blog.sina.com.cn/s/blog_7c03bb1f0100wcco.html 三态模型:在多道程序系统中,进程在处理器上交替运行,状态也不断地发生变化.进程一般有3种基本状态:运行.就绪和阻塞. (1)运行:当一个进程在处理机上运行时,则称该进程处于运行状态.处于此状态的进程的数目小于等于处理器的数目,对于单处理机系统,处于运行状态的进程只有一个.在没有其他进程可以执行时(如所有进程都在阻塞状态),通常会自动执行系统的空闲进程. (2)就绪:当一个进程获得了除处

进程的状态与转换

进程在其生命周期内通常进程有以下三种状态: 1) 运行状态:进程正在处理机上运行.在单处理机环境下,每一时刻最多只有一个进程处于运行状态. 2) 就绪状态:进程已处于准备运行的状态,即进程获得了除处理机之外的一切所需资源,一旦得到处理机即可运行. 3) 阻塞状态,又称等待状态:进程正在等待某一事件而暂停运行,如等待某资源为可用(不包括处理机)或等待输入/输出完成.即使处理机空闲,该进程也不能运行. 注意区别就绪状态和等待状态:就绪状态是指进程仅缺少处理机,只要获得处理机资源就立即执行:而等待状态

操作系统——进程的状态及转换

1.    为什么要分开就绪和阻塞状态 答:因为就绪态只需要等待处理机,而阻塞态可能在等待输入输出,即使分配给处理机也是徒劳,所以两状态图不妥.对于调度进程,只需要等待就绪队列里的进程,因为阻塞状态可以转换到就绪队列里去. 2.    进程五状态 1)       新状态:进程已经创建,但未被OS接纳为可执行进程.(还没有申请到相应的资源). 2)       就绪态:进程做好了准备,准备执行(只等待处理机). 3)       执行状态:该进程正在执行(单处理机,某一时刻仅一个进程占用处理机)

[转] 进程的状态

为了对进程从产生到消亡的整个过程进行跟踪和描述,就需要定义各种进程的各种状态并制定相应的状态转换策略,以此来控制进程的运行. 不同的操作系统对进程的状态解释不同,但是最基本的状态都是一样的.包括一下三种: 运行态:进程占用CPU,并在CPU上运行: 就绪态:进程已经具备运行条件,但是CPU还没有分配过来: 阻塞态:进程因等待某件事发生而暂时不能运行: 下面是3种状态转换图: 当然理论上上述三种状态之间转换分为六种情况: 运行--->就绪:这是有调度引起的,主要是进程占用CPU的时间过长 就绪--

进程的状态和切换(学习笔记)

时间:2014.05.28 地点:基地 ------------------------------------------------------------------------------- 一.进程的三种基本状态 进程的三种基本状态包括:就绪状态,执行状态,阻塞状态 1.就绪状态 当进程分配得到除CPU之外的所有必要资源后,只要再获得CPU就可以立即执行了,万事俱备只欠东风而已.该状态即就绪状态,一个系统中处于就绪状态的进程可能有很多,将他们排成一个队列,形成一个就绪队列. 2.执行状