zoukankan      html  css  js  c++  java
  • (C)程序控制块(TCB)

    程序控制块

    1. 程序控制块

    从代码上看,程序控制块就是一个结构体.例如:

    
    	typedef struct tcb{
    		char * tast_name; //任务名字
    		int    p; //任务重要级别
    		int    v_number; //版本号
    		void (*fun)(void); //指向存储任务代码空间地址
    	}TCB;
    

    操作系统可以通过这个结构体控制与之相关联的代码,因此把这种结构叫做程序控制块.
    例子:

    
    	#include <stdio.h>
    	#include <string.h>
    
    	//TCB定义
    	typedef struct tcb{
    		char * task_name; //任务名字
    		int    p; //任务重要级别
    		int    v_number; //版本号
    		void (*fun)(void); //指向存储任务代码空间地址
    	}TCB;
    
    	//任务1
    	void Task1()
    	{
    		int i;
    		for (i=0; i<10; i++)
    			printf("1111111111
    ");
    	}
    	
    	//任务2	
    	void Task2()
    	{
    		int i;
    		for (i=0; i<10; i++)
    			printf("222222222222
    ");
    	}
    	//任务3	
    	void Task3()
    	{
    		int i;
    		for (i=0; i<10; i++)
    			printf("3333333333333
    ");
    	}
    	//创建控制块函数
    	TCB GreatTCB(char *name, int pp, int vnum, void (*f)())
    	{
    		TCB tcb;
    		tcb.task_name = name;
    		tcb.p = pp;
    		tcb.v_number = vnum;
    		tcb.fun = f;
    		return tcb;
    	}
    
    	//主任务
    	int main()
    	{
    		char name_buf[10];
    		int t, i;
    		
    		//定义TCB数组大小
    		TCB tcbTbl[3];
    		
    		//创建task
    		tcbTbl[0] = GreatTCB("task1", 2, 1, Task1);
    		tcbTbl[1] = GreatTCB("task2", 3, 4, Task2);
    		tcbTbl[2] = GreatTCB("task3", 4, 4, Task3);
    		
    		printf("Input task name: ");
    		gets(name_buf);
    		
    		t = 0;
    		//seek 
    		for (i=0; i<3; i++)
    		{
    			if (strcmp(tcbTbl[i].task_name, name_buf) == 0)
    			{
    				tcbTbl[i].fun();
    				t = 1;
    			}
    		
    			if (i == 2 && t == 0)
    				printf("No %s
    ", name_buf);
    		}
    		return 0;
    	}
    

    2. 控制块链表

    为了方便管理和组织程序控制块,一版在TCB中再定义两个指针,一个前指针, 一个后指针,用于把TCB组织起来,方便管理; 并且当程序控制块数组过大时,还会单独定义一个数组,数组的各个元素分别按照顺序指向程序控制块链表,这样做的目的是为了提高程序运行速度,因为链表查询很耗时.

  • 相关阅读:
    matplotlib
    CNN中feature map、卷积核、卷积核个数、filter、channel的概念解释,以及CNN 学习过程中卷积核更新的理解
    Batch Normlization原理
    pycharts
    stm 32 LED(寄存器版本)
    stm32 滴答时钟实现较准时延时功能
    LFS笔记一:从LFS网站获取资源
    ubuntu 12.04编译安装linux3.6.10内核笔记
    stm32 外部事件<按键>中断输入实现过程<寄存器>
    stm32 中断几个库函数实现过程分析。
  • 原文地址:https://www.cnblogs.com/yanghong-hnu/p/5712240.html
Copyright © 2011-2022 走看看