预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共20页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

4.7进程通信4.8线程(二)线程及其特征 线程是调度执行的基本单位;线程不是资源分配的基本单位; 线程从属于某个进程,是该进程的某个执行路线。因此,也将进程称为重型进程,线程称为轻型进程。 线程是进程中的一个相对独立的可执行单元。 一个进程中至少包含一个线程。 由于同一进程内的线程之间涉及资源共享,所以需要同步机制来实现进程内多线程之间的通信。 与进程类似,线程还可以创建其它线程,线程也有生命周期,也有状态的变化。 (三)线程与进程的主要区别与联系(四)线程的状态与线程控制块(五)线程的分类2.内核级线程 内核级线程KLT(Kernel-LevelThread)中,所有线程的创建、调度、管理都由操作系统内核负责。一个用户进程可以按多线程方式编写程序,当它被提交给多线程操作系统运行时,内核为它创建一个进程和一个线程,线程在运行中还可以创建新的线程。我们称之为“纯KLT方法”。WindowsNT属于此类。 其优点在于: 内核可以调度一个进程中的多个线程,使其同时在多个处理器上并发运行,从而提高运行的速度和效率。 当进程中的一个线程被阻塞时,该进程中的其它线程仍可运行。 内核本身也可以用线程的方式实现。 其缺点在于: 同一进程中的线程切换要有两次态的转换(用户态→内核态→用户态),因为线程的调度运行在内核态,而应用程序运行在用户态。(六)线程举例1.Linux线程系统调用1.Linux线程系统调用2.Linux线程举例main() { /*定义线程内部标识*/ pthread_tthreadid; inti,ret; /*创建一个子线程并指定执行函数,函数不带参数*/ ret=pthread_create(&threadid,NULL,(void*)thread,NULL); if(ret!=0) { printf("Createpthreaderror!\n"); exit(1); }带有线程的源程序在进行编译时需要使用参数-lpthread:gcc-lpthread–o目标文件名源文件名编译和运行该程序后的结果为:3.多线程举例/*主线程*/ main() { inttid; pthread_tthreads[MAXTHREAD]; //定义多线程标识符数组 /*定义线程执行函数的参数*/ charmessage[][10]={"thread1","thread2","thread3","thread4","thread5"}; /*循环创建5个子线程*/ inti; for(i=0;i<5;i++) { /*创建子线程并指定执行函数及参数*/ tid=pthread_create(&threads[i],NULL,threaf_fuction,message[i]); if(tid!=0) { perror("Threadcreationfailed"); exit(1); } } /*主线程*/ for(i=0;i<5;i++) pthread_join(threads[i],NULL);//等待5个子线程终止 printf("Allthreadfinished.\n"); //输出结束提示 exit(0); }(七)Linux多线程同步下的信号量voidthread1() { pthread_mutex_lock(&count_lock); printf("thethread1enterthecirticalsection..\n"); sleep(2); printf("thethread1exitthecirticalsection..\n"); pthread_mutex_unlock(&count_lock); pthread_exit(NULL); } voidthread2() { pthread_mutex_lock(&count_lock) printf("thethread2enterthecirticalsection..\n"); sleep(2); printf("thethread2exitthecirticalsection..\n"); pthread_mutex_unlock(&count_lock); pthread_exit(NULL); }Semaphore: 变量定义:sem_tsem; 初始化:intsem_init(sem_t*sem,intpshared,unsignedintvalue); sem_init(&sem,0,1); 进入加锁:intsem_wait(sem_t*sem); sem_wait(&sem); 退出解锁:intsem_post(sem_t*sem); sem_post(&sem);作业