- 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实验报告精选
学 生 实 验 报 告
实验课程 网络技术
开课学院 计算机学院
任课教师 xxxx
学生姓名 xxxxx
专业班级
学生年级
2013-2014 学年 第二学期
一、实验目的:1.掌握Linux操作系统中多线程编程的基本原理和方法;
2.学会利用创建多线程实现单词统计.
二、实验原理:
1.多线程编程
线程在进程的基础上作进一步抽象,也就是说一个进程分为两个部分:线程集合和资源集合.线程是进程中的动态对象,它是一个独立的控制流,进程中的所有线程将共享进程拥有的资源.
在Linux中,可把线程分为内核线程、内核支持的用户线程和线程库支持的用户线程等3种类型.其中,内核编程负责实现一个指定系统功能;内核支持的用户线程实质上是特殊的进程,能被单独调度和运行;用户进程是通过线程库实现的,内核不参与调度,线程库提供同步和调度方法.
我们做实验所用到的正是多线程编程里的用户线程.每个用户线程都可以有自己的用户栈,即用来保存用户级寄存器上下文以及信号屏蔽等状态信息的主存区.线程库支持的用户线程不是真正的调度实体,内核对他们一无所知,而只是调度用户线程所属的线程,这些进程再通过线程库函数来调度进程内的用户线程.
2. 线程控制
(1)线程创建
#includepthread.h
int pthread_create(pthread_t *restrict tidp, const pthread_attr_t *restrict
attr, void *(*start_rtn)(void), void *restrict arg);
pthread_create()在调用线程的地址空间内创建一个新线程来运行.参数tidp为指向线程标识符的指针,可以使用attr参数来为新线程定义不同属性.使用默认属性时,将NULL赋给attr参数.第3个和第4个参数指定的函数star_rtn和传递给函数的参数arg.函数犯规0表示成功,非0表示失败.
(2)线程等待
#includepthread.h
int pthread_join(pthread_t thread, void **status);
父进程可以使用pthread_join()等候子线程终止.其中参数thread指定将要等待的线程,线程通过pthread_create()返回的标识符来指定;参数status是一个指向另一个指针的指针,用于指定返回值;如果线程使用pthread_exit(void*)返回一个值,它会经由status参数返回到父进程,线程的资源会直到父进程调用pthread_join()后才释放.函数返回0表示成功,非0表示失败.
(3)线程同步
pthread线程库中有许多同步原语,包括信号量、互斥锁、条件变量和读/写锁.
线程互斥量同步原语,只要解决临界区的使用,线程可以通过相应函数来创建、销毁和操作信号互斥量.它们的函数原型定义如下:
#includepthread.h
int pthread_mutex_init(pthread_mutex *mutex, const pthread_mutexattr_t *mutexattr);
int pthread_mutex_lock(pthread_mutex *mutex);
int pthread_mutex_unlock(pthread_mutex *mutex);
int pthread_mutex_destroy(pthread_mutex *mutex);
这些函数中的mutex参数是指向pthread_mutex互斥量的指针,函数返回0表示成功,非0表示失败.
线程终止
如果线程中任何一个线程调用函数exit(),那么整个进程就会终止.于此类似,如果信号的默认动作是终止进程,那么,把该信号发送到线程会终止进程.
线程的正常退出的方式包括以下几种:
线程只是从启动例程中返回,返回值是线程中的退出码.
线程可以被另一个线程终止.
线程自己调用pthread_exit().
区分单词原则:
凡是一个非字母或数字的字符跟在字母或数字的后面,那么这个字母这个字母或数字就是单词的结尾.
允许线程使用互斥锁来修改临界资源,确保线程间的同步与协作.如果两个线程需要安全地共享一个公共计数器,需要把公共计数器加锁.线程需要访问称为互斥锁的变量,它可以使线程间很好地合作,避免对于资源的
文档评论(0)