- 1、本文档共38页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[工学]互联网络程序设计第5章
第五章、多线程并发服务器与客户端 线程的基本概念 Posix线程库(创建、退出、join、detach) 迭代式客户端的问题 多线程并发客户端 线程安全与线程间通信 多线程并发服务器 测试用例 1. 线程的基本概念 在chap4.echo2的测试用例中,我们对比了多进程服务器与迭代式服务器的latency,可以发现多进程服务器的latency要比迭代式服务器长 使用进程并行的方式,一般来说有如下的缺陷 latency 内存资源占用 进程切换开销 进程间通信开销 要并行为客户端服务,除了采用进程方式外,多线程的方式值得考虑 线程可以看成是一种轻量进程,它是CPU调度的基本单位。多个线程同处于一个进程中,此时进程弱化为一个资源容器,进程不再是调度的基本单位 同一进程的多个线程间存在着资源共享,但是有些是线程独有的 Shared private Process instuctions thread ID Most data set of registers Open files stack Signal handlers errno User and group ID signal mask 2. Posix线程库 Solaris最先引入线程的概念,Unix系统中我们通常采用Pthread线程库来编程 线程的创建 线程的退出 线程的join 线程的detach 线程的创建 #include pthread.h int pthread_create(pthread_t *tid, const pthread_attr_t *attr, void (*func)(void *), void *arg); returns: 0 if OK, !=0, error. func表示一个函数指针,arg是该函数带的参数 /usr/include/bits/pthreadtypes.h typedef unsigned long int pthread_t; typedef union { char __size[__SIZEOF_PTHREAD_ATTR_T]; long int __align; } pthread_attr_t; main函数会缺省创建一个线程,这个线程称为主线程 pthread_attr_t指出创建线程的属性,包括优先级、栈的大小。如果调用pthread_create函数时,attr指针为NULL,则按照缺省属性创建 示例 pthread_t tid; status = pthread_create(tid, NULL, func, NULL); 线程的退出 #include pthread.h void pthread_exit(void *value_ptr); 没有返回值 为什么pthread_exit没有返回值? value_ptr指向一个信息块,该信息块用于向join的线程通告一些有用的信息 线程除了显示的调用pthread_exit函数外,可以直接return value_ptr;返回 pthread_exit与exit/_exit函数的区别 线程退出,并不会清理线程的资源,包括文件描述符的关闭、互斥变量的销毁的;但是,线程栈上的局部数据是不能被引用的 exit与_exit函数的动作 _exit()函数会清理进程打开的文件描述符,同时会将子进程托付给init进程 exit函数会调用atexit()函数注册的退出函数,同时flush掉IO缓冲,最后调用_exit函数 注意: exit/_exit函数是进程相关的函数,调用这两个函数意味着进程的退出,即该进程所有线程均需终止 main函数返回前,一定会调用_exit函数,所以main函数返回,就意味着进程的终止 基于这种原因,main对应的线程称为主线程 线程detach函数 #include pthread.
您可能关注的文档
- [工学]《机械CAMUG》课件-2.ppt
- [工学]《有机化学》高教版课后题答案.doc
- [工学]《水利水能规划》.ppt
- [工学]《材料研究方法》期末总复习.pdf
- [工学]《泵与风机》课件第5章.ppt
- [工学]《汇编语言程序设计》第十三章:中断及中断处理程序.ppt
- [工学]《电力电子技术》第五版 第10章 电力电子技术的应用.ppt
- [工学]《概率论与数理统计本科》复习题.doc
- [工学]《电工学》_秦曾煌主编第六版下册 电子技术 集成运算放大器.ppt
- [工学]《电工技术基础》电子教案 第5章 一阶动态电路分析.ppt
- 功能设计_MM_MM015_报废单_20080109_v2.0.doc
- 功能设计_MM_MM021_采购订单批导入程序_20080108_v1.0.doc
- 功能设计_MM_MM020_出库单_20071205_v2.1.doc
- 功能设计_MM_MM019_入库单_20071205_v2.1.doc
- 功能设计_MM_MM018_领料单_20080114_v2.0.doc
- 功能设计_MM_MM016_ERP与招投标系统接口_20080327_v1.2.doc
- 功能设计_MM_MM014_退库单_20080109_v1.0.doc
- 功能设计_MM_MM013_物料盘点清单_20080114_v2.0.doc
- 中考数学知识点10 一元一次不等式(组)(2).pdf
- 七年级数学优质课公开课教案教学设计期中综合检测.pdf
文档评论(0)