- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
LINUX环境高级编程-第六讲线程
Linux环境高级编程 第六讲 线程 第六讲 线程 线程的概念 线程的创建 线程的终止 线程的同步 线程属性 同步属性 取消选项 线程和信号 线程和fork 第六讲 线程 线程的概念 线程的创建 线程的终止 线程的同步 线程属性 同步属性 取消选项 线程和信号 线程和fork 线程的概念 进程的所有信息对该进程的所有线程都是共享的,包括可执行的程序文本、程序的全局内存、堆内存、文件描述符等 线程独有的:线程ID、寄存器值、栈、信号屏蔽字、errno值、线程私有数据 典型的UNIX进程,可以看成是只有一个线程的进程 线程的概念 同进程一样,每个线程也有一个线程ID 进程ID在整个系统中是唯一的,但线程ID不同,线程ID只在它所属的进程环境中有效 线程ID的类型是pthread_t,在Linux中的定义: 在/usr/include/bits/pthreadtypes.h中 typedef unsigned long int pthread_t; 线程的概念 pthread_self函数可以使调用线程获取自己的线程ID 函数原型 #includepthread.h pthread_t pthread_self(); 返回调用线程的线程ID 线程的概念 Linux中使用整型表示线程ID,而其他系统则不一定 FreeBSD 5.2.1、Mac OS X 10.3用一个指向pthread结构的指针来表示pthread_t类型。 为了移植性,在比较两个线程ID是否相同时,可以使用pthread_equal函数 pthread_equal函数 该函数用于比较两个线程ID是否相同 函数原型 #includepthread.h int pthread_equal(pthread_t tid1, pthread_t tid2); 若相等则返回非0值,否则返回0 线程的一种工作模式 Scalar和Erlang,Actor 第六讲 线程 线程的概念 线程的创建 线程的终止 线程的同步 线程属性 同步属性 取消选项 线程和信号 线程和fork 线程的创建 pthread_create函数用于创建一个线程 函数原型 #includepthread.h int pthread_create(pthread_t *restrict tidp, const pthread_attr_t *restrict attr, void *(*start_rtn)(void *), void *restrict arg); 参数与返回值 tidp:当pthread_create成功返回时,该函数将线程ID存储在tidp指向的内存区域中 pthread_create函数 参数与返回值 attr:用于定制各种不同的线程属性,将在后面部分讨论。通常可设为NULL,采用默认线程属性 start_rtn:线程的入口函数,即新创建的线程从该函数开始执行。该函数只有一个参数,即arg,返回一个指针 arg:作为start_rtn的第一个参数 成功返回0,出错时返回各种错误码 线程的创建 新创建的线程,将继承调用pthread_create函数的线程的信号屏蔽字,但新线程的未决信号集将被清除 示例6.1 编译:#g++ test.cpp –lpthread 程序6.1没有任何输出。其原因在于主线程先于新创建的线程退出 什么是主线程? 示例6.2 线程的封装 每次调用pthread_create很繁琐,能否简化线程的创建工作 示例6.3 为什么使用static函数? 为什么需要传递this指针? 为什么ThreadFunc是虚的? 为什么基类要使用virtual的析构? StartFunc是private的,为什么能够被调用? 线程的封装 示例6.4 模板的静态多态 示例6.5 基于接口的封装 基于接口的编程范式的好处 前面的程序是通过创建线程的方式打印 现在需要通过创建进程的方式打印 在6.3基础上的修改,示例6.7 在6.5基础上的修改,示例6.6 两者的区别 线程的封装 基于接口的编程模式,更有利于装配 在不改变处理类源代码的情况下,可以自由组合 继承是一种紧耦合的关系 耦合于实现 耦合于接口 而基于接口的编程模式,仅耦合于接口 线程的封装 另一种对象装配的机制(示例6.8) 要求可以任意选择是创建线程还是创建进程 要求被创建的线程或进程,可以选择是打印线程ID或者打印进程ID 整个程序中,三大部件均可配置 创建执行体的部件 执行体的执行部件 协调部件 CThread、CProcess为什么通过模板函数传递,而不同类模板传递基类类型? CBaseClassForCThread有何用? 线程的封装 CBaseClassForCThread是否存在问题? 被系
文档评论(0)