第1章 实时操作系统基础(g)_第1页
第1章 实时操作系统基础(g)_第2页
第1章 实时操作系统基础(g)_第3页
第1章 实时操作系统基础(g)_第4页
第1章 实时操作系统基础(g)_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、嵌入式实时操作系统嵌入式实时操作系统 C/OS原理与实践原理与实践教材和参考书籍教材教材 : 卢有亮,卢有亮,嵌入式实时操作系统嵌入式实时操作系统C/OS分析与实践(第分析与实践(第2版),版), 电子工业出版社电子工业出版社参考书籍:参考书籍: (1)Jean J. Labrosse著,邵贝贝译,著,邵贝贝译,嵌入式实时操作系统嵌入式实时操作系统C/OS-II(第(第2版),北航出版社版),北航出版社 (2)Jean J. Labrosse著,邵贝贝译,著,邵贝贝译,嵌入式实时操作系统嵌入式实时操作系统C/OS-III(第(第3版),北航出版社版),北航出版社 (3)任哲,嵌入式实时操作系统

2、)任哲,嵌入式实时操作系统C/OS-II原理及应用,北航出版社原理及应用,北航出版社网上学习参考教材作者讨论群教材作者讨论群 :教材作者网上授课视频:教材作者网上授课视频:在网上观看视频(土豆、优酷)在网上观看视频(土豆、优酷)http:/ 操作系统和嵌入式实时操作系统的基本原理。第二章第二章 任务管理,是基本内容,需要对数据结构和源代码仔细体会。第三章第三章 时间和中断管理,时间管理包括一些函数,中断管理主要是中断的流程。第四章、第五章第四章、第五章 事件和消息部分,包含了各种事件和消息机制。第六章第六章 内存管理。第第1 1章章 实时操作系统基础实时操作系统基础1.1 操作系统概述1.2

3、实时操作系统概述1.3 任务1.4 基于优先级的不可剥夺内核1.5 同步与通信 1.1 1.1 操作系统概述操作系统概述1.1.1 1.1.1 什么是操作系统什么是操作系统 操作系统操作系统OS(Operating System)是裸机上的第一层软件。是裸机上的第一层软件。 操作系统是计算机系统中最重操作系统是计算机系统中最重要的系统软件,是硬件的第一要的系统软件,是硬件的第一层封装与抽象,在计算机系统层封装与抽象,在计算机系统中占据着重要的地位,所有其中占据着重要的地位,所有其他的系统软件与应用软件都依他的系统软件与应用软件都依赖于操作系统的支持与服务。赖于操作系统的支持与服务。 除提供编程

4、接口,操作系统还除提供编程接口,操作系统还承担着承担着任务管理、事件管理和任务管理、事件管理和消息通信、消息通信、CPU管理、内存管管理、内存管理、理、IO管理管理等核心功能。等核心功能。1.1 1.1 操作系统概述操作系统概述1.1.2 1.1.2 操作系统基本功能操作系统基本功能1.1.任务管理任务管理2.CPU2.CPU管理管理3.3.内存管理内存管理4.4.文件管理文件管理5.IO5.IO设备管理设备管理任务是程序的一次执行。任务可以任务是程序的一次执行。任务可以分为系统任务和用户任务。系统任分为系统任务和用户任务。系统任务是操作系统本身的任务,如操作务是操作系统本身的任务,如操作系统

5、的主程序,时钟中断服务程序,系统的主程序,时钟中断服务程序,如后面要讲到的空闲任务和统计任如后面要讲到的空闲任务和统计任务等。用户任务是用户应用程序的务等。用户任务是用户应用程序的运行,如用户设计的计算器软件的运行,如用户设计的计算器软件的一次执行或一次执行或WORD软件的运行,软件的运行,如本书中给出的一些用户任务。这如本书中给出的一些用户任务。这些任务都需要任务管理部分来管些任务都需要任务管理部分来管理。理。CPU管理的含义在于多任务管理的含义在于多任务OS对对CPU的分配,也就是分配对的分配,也就是分配对CPU的所有权,简单说,哪个软件正在的所有权,简单说,哪个软件正在运行,占有运行,占

6、有CPU。可以把它归入。可以把它归入任务管理。任务管理。内存是任务的生存空间。内存管理内存是任务的生存空间。内存管理用于给任务分配内存空间,相应的,用于给任务分配内存空间,相应的,在任务结束后释放内存空间。在任务结束后释放内存空间。文件管理系统是实现对文件的统一文件管理系统是实现对文件的统一管理,是对文件存储器的存储空间管理,是对文件存储器的存储空间进行组织,分配和回收,负责文件进行组织,分配和回收,负责文件的存储,检索,共享和保护。从用的存储,检索,共享和保护。从用户角度来看,文件系统主要是实现户角度来看,文件系统主要是实现按名取存按名取存,文件系统的用户只要,文件系统的用户只要知道所需文件

7、的文件名,就可存取知道所需文件的文件名,就可存取文件中的信息,而无需知道这些文文件中的信息,而无需知道这些文件究竟存放在什么地方。件究竟存放在什么地方。 管理系统中的各种硬件设备,如打管理系统中的各种硬件设备,如打印机,显示器,硬盘等。很明显,印机,显示器,硬盘等。很明显,用户应用程序应该调用用户应用程序应该调用IO设备管理设备管理模块提供的模块提供的API来对设备进行操作,来对设备进行操作,而不是直接读写硬件。而不是直接读写硬件。51.2 1.2 实时操作系统概述实时操作系统概述 实时操作系统RTOS(Real Time Operating System)是指当外界事件或数据产生时,能够接收

8、并以足够快的速度予以处理,其处理的结果又能在规定的时间之内来控制生产过程或对处理系统作出快速响应,并控制所有实时任务协调一致运行的操作系统。实时系统与非实时系统的本质区别就在于实时系统中的任务都有时间限制。1.2.1 1.2.1 什么是实时操作系统什么是实时操作系统1.2 1.2 实时操作系统概述实时操作系统概述1.实时操作系统首先是多任务操作系统。2.多级中断机制。3.优先级调度机制。 .1实时操作系统基本特征实时操作系统基本特征1.3 1.3 任务任务1.3.1 1.3.1 任务的概念任务的概念 任务是程序的动态表现,在操作系统中体现为线程,是任务是程序的动态表现,在操作系

9、统中体现为线程,是程序的一次执行过程。程序的一次执行过程。程序是静止静止的,存在于ROM、硬盘等外部设备。任务是运动运动的,存在于内存中,有睡眠、就绪、运行、阻塞、挂起等多种状态。相同的程序的多次执行是可以的多次执行是可以的,就形成了多个优先级不同的任务,每一个都是独立的。在实时系统中,把应用程序的设计过程分割为多个任务,每个任务都有自己的优先级优先级,在操作系统的调度下协调运行。 任务的一个例子任务的一个例子void usertask(void *pParam)INT8U i=0;for(;)printf(%dn,i);i+;OSTimeDly(100);见识一下RTOS中的任务1.3.2

10、1.3.2 多任务多任务 实时操作系统的是多任务的操作系统,系统中必然有多实时操作系统的是多任务的操作系统,系统中必然有多任务在执行。任务在执行。 任务的种类:任务的种类:R 用户任务,如前面的usertask;R 系统任务,如空闲任务和统计任务。 多任务的的优点:多任务的的优点:R 可以大大提高CPU的利用率;R 使应用程序分成多个程序模块,实现模块化,应用程序更易于设计和维护。 看看两个任务执行的情况看看两个任务执行的情况创建任务创建任务运行结果运行结果21.3.3 1.3.3 任务的状态任务的状态创创建建任任务务睡睡眠眠态态就就绪绪态态删删除除任任务务运运行行态态任任务务切切换换任任务务

11、切切换换删删除除任任务务阻阻塞塞态态事事件件等等待待删删除除任任务务等等待待的的事事件件发发生生挂挂起起态态中中断断返返回回( (仍仍为为最最高高优优先先级级) )返返回回( (不不是是最最高高优优先先级级) )1.睡眠态睡眠态任务已经被装入内存了,可是并没有准备好运行。例如上面给出的任务已经被装入内存了,可是并没有准备好运行。例如上面给出的usertask代码,以代码的形式存在于内存中,在调用代码,以代码的形式存在于内存中,在调用OSTaskCreate(任务创建函数)创建之前,处于睡眠态。睡眠态(任务创建函数)创建之前,处于睡眠态。睡眠态的任务不会得到运行的,操作系统也不会给其设置为运行而

12、准备的的任务不会得到运行的,操作系统也不会给其设置为运行而准备的数据结构。数据结构。2.就绪态就绪态当操作系统调用当操作系统调用OSTaskCreate创建一任务后,任务就进入就绪态。创建一任务后,任务就进入就绪态。从图从图1.4还可以看出,任务也可以从其他状态转到就绪态。处于就还可以看出,任务也可以从其他状态转到就绪态。处于就绪态的任务操作系统已经为其运行配置好了任务控制块等数据结构,绪态的任务操作系统已经为其运行配置好了任务控制块等数据结构,当没有比其更高优先级的任务,或比其优先级更高的任务处于阻塞当没有比其更高优先级的任务,或比其优先级更高的任务处于阻塞状态的时候,就能被操作系统调度而进

13、入运行态。从就绪态到运行状态的时候,就能被操作系统调度而进入运行态。从就绪态到运行态,操作系统调用任务切换函数完成。态,操作系统调用任务切换函数完成。3.运行态运行态任务真正占有任务真正占有CPU,得到运行。这时运行的代码就是任务的代码。,得到运行。这时运行的代码就是任务的代码。如如usertask。处于运行态的任务如果运行完成,就会转为睡眠态。处于运行态的任务如果运行完成,就会转为睡眠态。如果有更高优先级的任务抢占了如果有更高优先级的任务抢占了CPU,就会转到就绪态。如果因,就会转到就绪态。如果因为等待某一事件,例如等待一秒钟的时间,如为等待某一事件,例如等待一秒钟的时间,如OSTimeDl

14、y(OS_TICKS_PER_SEC),需要暂时放弃,需要暂时放弃CPU的使用的使用权而让其他任务得以运行,就进入了阻塞状态。当由于中断的到来权而让其他任务得以运行,就进入了阻塞状态。当由于中断的到来而使而使CPU进入中断服务程序(进入中断服务程序(ISR),必然使正在运行的任务放弃),必然使正在运行的任务放弃CPU而转入中断服务程序,这时被中断的程序就被挂起而进入挂而转入中断服务程序,这时被中断的程序就被挂起而进入挂起态。起态。总之,任务要得到运行必须进入运行态,总之,任务要得到运行必须进入运行态,CPU只有一个不能让每只有一个不能让每个任务同时进入运行态,进入运行态的任务有且只有一个。个任

15、务同时进入运行态,进入运行态的任务有且只有一个。4.阻塞阻塞阻塞对于操作系统的调度,任务的协调运行是非常重要的。我们能阻塞对于操作系统的调度,任务的协调运行是非常重要的。我们能看到图看到图1.3的运行结果,而不是只有一个高优先级的任务得到运行,的运行结果,而不是只有一个高优先级的任务得到运行,就是因为就是因为usertask在没有事情可做,等待一秒钟的时候,不是强在没有事情可做,等待一秒钟的时候,不是强行运行代码,而是把自己阻塞起来,使操作系统可以调度其他的任行运行代码,而是把自己阻塞起来,使操作系统可以调度其他的任务。务。当任务在等待某些还没有被释放的资源,等待一定的时间等时候,当任务在等待

16、某些还没有被释放的资源,等待一定的时间等时候,要阻塞起来,等到条件满足的时候再重新回到就绪态,又能被操作要阻塞起来,等到条件满足的时候再重新回到就绪态,又能被操作系统调度以进入运行态,这是实时系统必须要实现的功能之一。系统调度以进入运行态,这是实时系统必须要实现的功能之一。一些不理解操作系统的同学在编程的时候,在等待的时候常常使用一些不理解操作系统的同学在编程的时候,在等待的时候常常使用FOR循环,不停的执行代码而使循环,不停的执行代码而使CPU的利用率暴增,使系统的运的利用率暴增,使系统的运行环境十分恶劣,甚至造成死机,是不可取的行环境十分恶劣,甚至造成死机,是不可取的5.挂起态挂起态当任务

17、在运行时,因为中断的发生,例如定时器中断每个时钟滴答当任务在运行时,因为中断的发生,例如定时器中断每个时钟滴答(clock tick,指每个时钟周期)中断一次,而被剥夺指每个时钟周期)中断一次,而被剥夺CPU的使用权,的使用权,而进入挂起态。在中断返回的时候,若该任务还是最高优先级的,而进入挂起态。在中断返回的时候,若该任务还是最高优先级的,就恢复运行,如果不是这样,只能回到就绪态。就恢复运行,如果不是这样,只能回到就绪态。51.3.4 1.3.4 任务切换任务切换 任务切换就是任务切换就是context switch,是任务调度的重要部分。,是任务调度的重要部分。从字面上是上下文切换。任务切

18、换是暂停一个任务的运从字面上是上下文切换。任务切换是暂停一个任务的运行,运行另一个就绪的任务。暂停一个任务,以后又能行,运行另一个就绪的任务。暂停一个任务,以后又能恢复运行,必须考虑将这个任务运行的信息保存,而恢恢复运行,必须考虑将这个任务运行的信息保存,而恢复运行的时候需要将这些信息恢复到运行环境。复运行的时候需要将这些信息恢复到运行环境。 任务切换必须做环境的保存和恢复的操作。任务切换必须做环境的保存和恢复的操作。 在操作系统移植的时候,任务切换代码就是必须要实现在操作系统移植的时候,任务切换代码就是必须要实现的部分之一。的部分之一。 (移植最为困难的部分)1.3.5 1.3.5 可重入和

19、不可重入函数可重入和不可重入函数函数可重入是指一个函数可以被多个任务调用,而不需要担心函数可重入是指一个函数可以被多个任务调用,而不需要担心在任务切换的过程中,代码的执行会产生错误的结果。在任务切换的过程中,代码的执行会产生错误的结果。如果函数被多个任务调用,可能产生错误的结果,就是重入函如果函数被多个任务调用,可能产生错误的结果,就是重入函数数 。int a,b;int add1(int *p1,int *p2) int a,b; a=*p1; b=*p2; OSTimeDly(OS_TICKS_PER_SEC); c=a+b; return(c);int add2(int p1,int p

20、2) /int a,b; a=p1; b=p2; OSTimeDly(OS_TICKS_PER_SEC); c=a+b; return(c);void usertask1(void *pParam) int sum; for(;) sum=add2(1,2); printf(ntask%d call add2(1,2) solution is %dn,1,sum); void usertask2(void *pParam) int sum; for(;) sum=add2(100,200); printf(ntask%d call add2(100,200) solution is %dn,2

21、,sum); 如下两个任务分别同时调用上述函数运行的结果是什么?如下两个任务分别同时调用上述函数运行的结果是什么?1.4 1.4 内核内核1.4.1 1.4.1 内核内核 内核是操作系统最核心的部分,其主要功能就是进内核是操作系统最核心的部分,其主要功能就是进行任务调度。行任务调度。 所谓调度,就是决定多任务的运行状态,哪个任务所谓调度,就是决定多任务的运行状态,哪个任务应该处于图应该处于图1.4中的哪种状态。中的哪种状态。 内核中最最核心的基本服务就是调度的核心内核中最最核心的基本服务就是调度的核心任任务切换务切换 C/OS使用的是一种基于优先级的可剥夺型内核。使用的是一种基于优先级的可剥夺

22、型内核。1.4.2 1.4.2 基于优先级的调度算法基于优先级的调度算法 在在C/OS-II中,可以同时有中,可以同时有64个就绪任务,每个任个就绪任务,每个任务都有各自的优先级。务都有各自的优先级。 优先级用无符号整数来表示,从优先级用无符号整数来表示,从0到到63,数字越大,数字越大则优先级越低。则优先级越低。 C/OS总是调度就绪了的,优先级最高的任务获得总是调度就绪了的,优先级最高的任务获得CPU的控制权,不管这个任务是什么,执行什么样的控制权,不管这个任务是什么,执行什么样的功能,也不管该任务是否已经等了很久。的功能,也不管该任务是否已经等了很久。1.4.3 1.4.3 不可剥夺和可

23、剥夺内核不可剥夺和可剥夺内核( (抢占优先级的问题抢占优先级的问题) )1.5 1.5 同步和通信同步和通信1.5.1 1.5.1 同步同步 任务是独立的,任务是独立的,但是任务之间又有着各种各样的但是任务之间又有着各种各样的关系,以成为一个整体,来完成某一项工作。关系,以成为一个整体,来完成某一项工作。有时候一有时候一个任务完成的前提是需要另一个任务给出一个结果,任个任务完成的前提是需要另一个任务给出一个结果,任务之间的这种制约性的合作运行机制叫做任务间的同步。务之间的这种制约性的合作运行机制叫做任务间的同步。 例如,A任务实现计算功能,B任务输出A任务计算的结果,然后循环运行。A任务和B任

24、务就必须同步,否则B任务输出的可能不是A任务刚完成的结果,或则B任务访问结果时,A任务正在修改,因而输出错误的结果。A和B就是必须进行同步的任务。 1.5.2 1.5.2 互斥互斥 前面的例子中,前面的例子中,A和和B两个任务都要访问计算结果这个两个任务都要访问计算结果这个共享,但是在共享,但是在A写这个资源的同时,写这个资源的同时,B必须等待,而不必须等待,而不能在能在A写到一半的时候结束写到一半的时候结束A而让而让B来读,这样会产生来读,这样会产生灾难性的后果。灾难性的后果。这样的共享资源称为临界资源(这样的共享资源称为临界资源(Critical Resource)。)。这种访问共享资源的

25、排他性就是互斥。这种访问共享资源的排他性就是互斥。资源的特征:占用性资源的特征:占用性1.5.3 1.5.3 临界区临界区 每个任务中访问共享资源的那段程序称为临界区(每个任务中访问共享资源的那段程序称为临界区(Critical Section),因为共享资源的访问是要互斥的。在临界区不),因为共享资源的访问是要互斥的。在临界区不允许任务切换,允许任务切换, 这是最根本的原则。因为如果在访问共享这是最根本的原则。因为如果在访问共享资源的时候进行任务切换,就可能发生前面提到的灾难性后资源的时候进行任务切换,就可能发生前面提到的灾难性后果。因此,在进入临界区访问共享资源之前,采用关中断,果。因此,

26、在进入临界区访问共享资源之前,采用关中断,给调度器上锁或使用信号量的方法,达到互斥的目的。给调度器上锁或使用信号量的方法,达到互斥的目的。 int function(void) OS_ENTER_CRITICAL;/访问临界资源访问临界资源OS_EXIT_CRITICAL;/其它程序代码其它程序代码1.5.4 1.5.4 任务事件任务事件 事件(事件(Event)就是在操作系统运行过程中发生的事)就是在操作系统运行过程中发生的事情。例如任务被挂起、唤醒、创建等。一般都是引情。例如任务被挂起、唤醒、创建等。一般都是引起操作系统任务调度执行的事情。起操作系统任务调度执行的事情。 事件管理实现了任务

27、同步和互斥的机制(功能)。事件管理实现了任务同步和互斥的机制(功能)。 C/OS操作系统在处理任务的同步和通信等环节,操作系统在处理任务的同步和通信等环节,大量的使用了事件这一概念,创建了大量的使用了事件这一概念,创建了事件控制块事件控制块这这样的数据结构以进行事件的管理。样的数据结构以进行事件的管理。 1.5.5 1.5.5 信号量信号量在一个时刻,有些共享资源只可以被一个任务所占有,而在一个时刻,有些共享资源只可以被一个任务所占有,而有些可以被至多有些可以被至多N个任务所共享。前一种共享资源就好比有个任务所共享。前一种共享资源就好比有一把钥匙,钥匙发出去了,得到钥匙的任务可以访问共享一把钥

28、匙,钥匙发出去了,得到钥匙的任务可以访问共享资源,其他请求该资源的任务必须等得到钥匙的任务把钥资源,其他请求该资源的任务必须等得到钥匙的任务把钥匙归还。后者则可以有匙归还。后者则可以有N把钥匙,如果把钥匙,如果N把钥匙都发完了,把钥匙都发完了,第第N+1个请求访问共享资源的任务就必须等待。这些钥匙个请求访问共享资源的任务就必须等待。这些钥匙就可以用信号量(就可以用信号量(semaphore)来表示。)来表示。信号量标志了共享资源的有效可被访问数量,于是要获得信号量标志了共享资源的有效可被访问数量,于是要获得共享资源的访问权,就首先要得到信号量这把钥匙。共享资源的访问权,就首先要得到信号量这把钥

29、匙。 信号量三种操作:信号量三种操作:1.建立(建立(create)建立并初始化信号量,在一个事件块里标志该信号,记录该信号的建立并初始化信号量,在一个事件块里标志该信号,记录该信号的量值,执行的是给资源配钥匙的操作。该操作的条件是系统中还有量值,执行的是给资源配钥匙的操作。该操作的条件是系统中还有空余的事件块。操作系统能处理的事件是有限的,任何的数据结构空余的事件块。操作系统能处理的事件是有限的,任何的数据结构都不能无限,尤其是在实时系统中。都不能无限,尤其是在实时系统中。2.请求(请求(pend)请求信号,如果还有钥匙(信号量大于请求信号,如果还有钥匙(信号量大于0),就去领一把(信号量)

30、,就去领一把(信号量-),执行下去;如果没有,就要把自己阻塞掉,因为不能执行下),执行下去;如果没有,就要把自己阻塞掉,因为不能执行下去就不需要再占用宝贵的去就不需要再占用宝贵的CPU。3.释放(释放(post)访问资源的操作完成后就把钥匙交回(信号量访问资源的操作完成后就把钥匙交回(信号量+)。这时,如果)。这时,如果有等待该钥匙的任务就绪,并比当前任务有更高的优先级,就执行有等待该钥匙的任务就绪,并比当前任务有更高的优先级,就执行任务调度。否则,原任务在释放信号量之后继续执行。任务调度。否则,原任务在释放信号量之后继续执行。 信号量机制的实现信号量机制的实现.6互斥信号量互

31、斥信号量 互斥信号量是一种特殊的信号量,这不仅在于该信互斥信号量是一种特殊的信号量,这不仅在于该信号量只有用于互斥资源的访问,还在于使用互斥信号量号量只有用于互斥资源的访问,还在于使用互斥信号量管理需要解决的优先级反转问题。管理需要解决的优先级反转问题。 如系统中有三个任务分别是高优先级、中优先级和如系统中有三个任务分别是高优先级、中优先级和低优先级的,当低优先级的任务在运行的时候访问互斥低优先级的,当低优先级的任务在运行的时候访问互斥资源,而中优先级的任务运行的时候将使低优先级的任资源,而中优先级的任务运行的时候将使低优先级的任务得不到运行而死抱着资源不放。这是高优先级的任务务得不到运行而死

32、抱着资源不放。这是高优先级的任务开始运行的时候,必须等待中优先级的任务运行完成,开始运行的时候,必须等待中优先级的任务运行完成,然后等低优先级的任务访问资源完成才行。如果在低优然后等低优先级的任务访问资源完成才行。如果在低优先级的任务访问资源过程中又有中优先级任务运行,那先级的任务访问资源过程中又有中优先级任务运行,那么高优先级的任务只有继续等待。么高优先级的任务只有继续等待。这种情况就是优先级这种情况就是优先级反转反转 。1.5.7 1.5.7 事件标志组事件标志组 在信号量和互斥信号量的管理中,任务请求资源,在信号量和互斥信号量的管理中,任务请求资源,如果资源未被占用就可继续运行,否则只能

33、阻塞,等待如果资源未被占用就可继续运行,否则只能阻塞,等待资源释放的事件发生。这种事件是单一的事件。如果任资源释放的事件发生。这种事件是单一的事件。如果任务要等待多个事件的发生,或多个事件中的某一个事件务要等待多个事件的发生,或多个事件中的某一个事件的发生就可以继续运行,那么就应该采用事件标志组管的发生就可以继续运行,那么就应该采用事件标志组管理。理。 事件标志组管理的条件组合可以是多个事件都发生,事件标志组管理的条件组合可以是多个事件都发生,也可以是多个事件中有任何一个事件发生。尤其特别的也可以是多个事件中有任何一个事件发生。尤其特别的是,还可以是多个事件都没有发生或多个事件中有任何是,还可

34、以是多个事件都没有发生或多个事件中有任何一个事件没有发生。一个事件没有发生。 1.5.8 1.5.8 消息邮箱和消息队列消息邮箱和消息队列邮箱邮箱(MailBox)很明显是用于通信的,邮箱中的内容一般很明显是用于通信的,邮箱中的内容一般是信件。操作系统也通过邮箱来管理任务间的通信与同步,是信件。操作系统也通过邮箱来管理任务间的通信与同步,邮箱中的内容却不是信件本身,而是指向消息内容的地址!邮箱中的内容却不是信件本身,而是指向消息内容的地址!这个指针是这个指针是void类型的,可以指向任何的数据结构。因而类型的,可以指向任何的数据结构。因而这样的设计更经济,所发送的信息范围也就更宽,邮箱中这样的设计更经济,所发送的信息范围也就更宽,邮箱中可以容纳下任何长度的数据了。可以容纳下任何长度的数据了。消息队列(消息队列(message queue)也用于给任务发消息,但)也用于给任务发消息,但是它是由多个消息邮箱组合形成

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论