欢迎来到天天文库
浏览记录
ID:40567967
大小:39.00 KB
页数:4页
时间:2019-08-04
《Linux下的多线程》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、多线程 计算机在运行时其执行过程从大到小可以分为作业、进程、和线程三个等级。所谓线程(thread),是系统能够调度和分派的最基本单位。线程自己并不拥有系统资源,只是在运行的时候占用一点必不可少的资源。如果在一个程序中同时运行多个线程来完成不同的工作,则称之为多线程。显然,多线程可以刚方便地体现“并行”特性,而且由于线程的轻量级,因此能够大大提高系统效率;而且在多CPU的硬件前提下更可以充分利用多核资源,因此被引入到操作系统之中。Linux下的多线程 Linux系统下的多线程遵循POSIX线程接口,称之为pthread。多线程编程的源程序必
2、须包含头文件pthread.h,因为线程库libpthread.a并不属于Linux系统的默认库,因此在编译时需要加上-lpthread参数。举例如下:exampthread.c#include#includevoidthread(void){inti;for(i=0;i<3;i++)printf("Thisisapthread.");}intmain(void){pthread_tid;inti,ret;ret=pthread_create(&id,NULL,(void*)thread,NULL);if(ret!=
3、0){printf("Createpthreadfail!");exit(1);}for(i=0;i<3;i++)printf("Thisisthemainprocess.");pthread_join(id,NULL);return0;}MakefileCC=arm-linux-gcc#CC=gccOBJS2=exampthread.oEXEC2=exampthreadall:$(EXEC2)$(EXEC2):$(OBJS2) $(CC)-o$@$(OBJS2)-lpthreadclean: rm-f$(EXEC2)$(OBJS2)result:运行
4、example1,我们得到如下结果: Thisisthemainprocess. Thisisapthread. Thisisthemainprocess. Thisisthemainprocess. Thisisapthread. Thisisapthread.再次运行,我们可能得到如下结果: Thisisapthread. Thisisthemainprocess. Thisisapthread. Thisisthemainprocess. Thisisapthread. Thisisthemainproce
5、ss.前后两次结果不一样,这是两个线程争夺CPU资源的结果。多线程编程所用到的主要函数 上面的示例中,我们使用到了两个函数, pthread_create和pthread_join,并声明了一个pthread_t型的变量。pthread_t在头文件/usr/include/bits/pthreadtypes.h中定义:typedefunsignedlongintpthread_t; 它是一个线程的标识符。函数pthread_create用来创建一个线程,它的原型为: externintpthread_create__P((pthread
6、_t*__thread,__constpthread_attr_t*__attr,void*(*__start_routine)(void*),void*__arg)); 第一个参数为指向线程标识符的指针,第二个参数用来设置线程属性,第三个参数是线程运行函数的起始地址,最后一个参数是运行函数的参数。这里,我们的函数thread不需要参数,所以最后一个参数设为空指针。第二个参数我们也设为空指针,这样将生成默认属性的线程。对线程属性的设定和修改我们将在下一节阐述。当创建线程成功时,函数返回0,若不为0则说明创建线程失败,常见的错误返回代码为EAGAIN和EIN
7、VAL。前者表示系统限制创建新的线程,例如线程数目过多了;后者表示第二个参数代表的线程属性值非法。创建线程成功后,新创建的线程则运行参数三和参数四确定的函数,原来的线程则继续运行下一行代码。 函数pthread_join用来等待一个线程的结束。函数原型为: externintpthread_join__P((pthread_t__th,void**__thread_return)); 第一个参数为被等待的线程标识符,第二个参数为一个用户定义的指针,它可以用来存储被等待线程的返回值。这个函数是一个线程阻塞的函数,调用它的函数将一直等待到被等待的线
8、程结束为止,当函数返回时,被等待线程资
此文档下载收益归作者所有