操作系统实验5-线程管理与控制

操作系统实验5-线程管理与控制

ID:33193169

大小:532.00 KB

页数:9页

时间:2019-02-21

操作系统实验5-线程管理与控制_第1页
操作系统实验5-线程管理与控制_第2页
操作系统实验5-线程管理与控制_第3页
操作系统实验5-线程管理与控制_第4页
操作系统实验5-线程管理与控制_第5页
资源描述:

《操作系统实验5-线程管理与控制》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、.第4章线程管理与控制4.1线程概念简介每个进程都拥有自己的数据段、代码段和堆栈段,这就造成了进程在进行切换等操作时都需要有比较复杂的上下文切换等动作。为了进一步减少处理机的空转时间,支持多处理器以及减少上下文切换开销,进程在演化中出现了另一个概念——线程。它是进程内独立的一条运行路线,处理器调度的最小单元,也可以称为轻量级进程。线程可以对进程的内存空间和资源进行访问,并与同一进程中的其他线程共享。因此,线程的上下文切换的开销比创建进程小很多。同进程一样,线程也将相关的执行状态和存储变量放在线程控制块(TCB)内。一个进程可以有多个线程,也就是有多个线程控制块及堆栈寄存器,但却

2、共享一个用户地址空间。要注意的是,由于线程共享了进程的资源和地址空间,因此,任何线程对系统资源的操作都会给其他线程带来影响。由此可知,多线程中的同步是非常重要的问题。在多线程系统中,进程与进程的关系如图所示。进程与线程关系4.2Linux多线程编程API与实验任务4.3.1Linux多线程编程API...创建线程pthread_create()函数实际上就是确定调用该线程函数的入口点,在线程创建以后,就开始运行相关的线程函数,在该函数运行完之后,该线程也就退出了,这也是线程退出一种方法。另一种退出线程的方法是使用函数pthread_exit(),这是线程的主动行为。这里要注意的

3、是,在使用线程函数时,不能随意使用exit()退出函数进行出错处理,由于exit()的作用是使调用进程终止,往往一个进程包含多个线程,因此,在使用exit()之后,该进程中的所有线程都终止了。因此,在线程中就可以使用pthread_exit()来代替进程中的exit()。由于一个进程中的多个线程是共享数据段的,因此通常在线程退出之后,退出线程所占用的资源并不会随着线程的终止而得到释放。正如进程之间可以用wait()系统调用来同步终止并释放资源一样,线程之间也有类似机制,那就是pthread_join()函数。pthread_join()可以用于将当前线程挂起来等待线程的结束。这

4、个函数是一个线程阻塞的函数,调用它的函数将一直等待到被等待的线程结束为止,当函数返回时,被等待线程的资源就被收回。(1)创建线程函数pthread_create()功能:创建线程和启动线程,与进程管理函数fork()的功能相似。pthread_create()函数语法要点所需头文件#include函数原型intpthread_create(pthread_t*thread,pthread_attr_t*attr,void*(*start_routine)(void*),void*arg))函数传入值thread:线程标识符attr:线程属性设置(其具体设置

5、参见9.2.3小节),通常取为NULLstart_routine:线程函数的起始地址,是一个以指向void的指针作为参数和返回值的函数指针arg:传递给start_routine的参数函数返回值成功:0出错:返回错误码(2)线程退出函数pthread_exit()pthread_exit()函数语法要点所需头文件#include函数原型voidpthread_exit(void*retval)函数传入值retval:线程结束时的返回值,可由其他函数如pthread_join()来获取(3)等待线程结束函数pthread_join()...等待线程结束,读取

6、线程的返回结果。pthread_join()函数语法要点所需头文件#include函数原型intpthread_join(pthread_tth,void**thread_return)函数传入值th:等待线程的标识符thread_return:用户定义的指针,用来存储被等待线程结束时的返回值(不为NULL时)函数返回值成功:0出错:返回错误码(4)线程取消函数pthread_cancel()pthread_cancel()函数语法要点所需头文件#include函数原型intpthread_cancel((pthread_tth)函数

7、传入值th:要取消的线程的标识符函数返回值成功:0出错:返回错误码4.3.3Linux多线程同步API1.线程同步信号量及系统调用POSIX的线程同步信号量定义了3个函数:(1)信号量初始化函数说明:#includeintsem_init(sem_t*sem,intpshared,unsignedvalue);参数说明:sem:指向信号量变量的指针,*sem是定义好的信号量。pshared:为0表示进程局部信号量,通常为0...value:信号量初始值,为1时是二值

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。