现在的位置: 首页 > 编程语言 > 正文

c线程中sleep()和pthread_join()函数之我见

2019年07月22日 编程语言 ⁄ 共 1972字 ⁄ 字号 评论关闭

线程之我见,有错误,请指正,谢谢

线程的执行需要cpu资源,而cpu的利用时各个线程进行“轮询”即轮时间片,抛开优先级不说,一个线程如果执行的时候,分配给他的时间片到了,他就要交出cpu执行权,由其他等待cpu的线程来执行,(一个cpu一次只能执行一个线程)。

而sleep()的作用是让当前执行cpu的线程挂起,交出cpu,让其他等待cpu的线程执行,

测试程序:

 1 #include<stdio.h>
 2 #include<pthread.h>
 3 #include<stdlib.h>
 4 void *fun(void *p){
 5     int i=0;
 6     for(i;i<10;i++){
 7         printf("fun i=%d\n",i);
 8     }
 9     printf("fun bye bye\n");
10     return NULL;
11 }
12 int main(){
13     pthread_t th;
14     if(pthread_create(&th,NULL,fun,NULL)<0){//pthread_create()函数参数请百度
15         perror("pthread_create");
16         return -1;
17     }
18     printf("main bye bye\n");
19     return 0;
20 }

 

如果是上面程序的话,在主线程main中没有sleep()和pthread_join()函数,猜一猜运行结果如何,

 

对,没错,只运行了主线程main,那么如果在main函数中加入sleep()函数的话(sleep参数不是0),那么是否是我们想要的结果呢?

测试程序:

 1 #include<stdio.h>
 2 #include<pthread.h>
 3 #include<stdlib.h>
 4 void *fun(void *p){
 5     int i=0;
 6     for(i;i<10;i++){
 7         printf("fun i=%d\n",i);
 8     }
 9     printf("fun bye bye\n");
10     return NULL;
11 }
12 int main(){
13     pthread_t th;
14     if(pthread_create(&th,NULL,fun,NULL)<0){//pthread_create()函数参数请百度
15         perror("pthread_create");
16         return -1;
17     }
18     sleep(1);//参数不为0
19     printf("main bye bye\n");
20     return 0;
21 }

运行结果:

果然是进入子线程fun中执行了,我猜操作系统是这样运行的:先是main线程,执行,经过create子线程的时候,创造出来的线程是就绪态,在等待队列中等待cpu的执行,现在还是main线程执行,在没有sleep函数的时候,main执行到return 0程序末尾的时候,main结束了,释放了空间,这时候子线程fun由main创造出来,主(进程)释放掉空间了,所以他就没法执行了;在main中有sleep函数的时候,main线程睡觉挂起了,把cpu交出来让给其他等待执行的线程去了,这时候子线程fun得以执行,执行完了,返回到main中继续执行。

由此猜想:如果他们都是在轮时间片的话,是否在main线程用光了时间片后会交出cpu执行权呢?

测试程序:

 1 #include<stdio.h>
 2 #include<pthread.h>
 3 #include<stdlib.h>
 4 int flag=1;//全局标志位
 5 void *fun(void *p){
 6     int i=0;
 7     for(i;i<10;i++){
 8         printf("fun i=%d\n",i);
 9     }
10     printf("fun bye bye\n");
11     flag=0;
12     return NULL;
13 }
14 int main(){
15     pthread_t th;
16     if(pthread_create(&th,NULL,fun,NULL)<0){//pthread_create()函数参数请百度
17         perror("pthread_create");
18         return -1;
19     }
20 //    sleep(1);//这次不用sleep函数,看是否main在用光了时间片后会交出时间片让其他等待程序执行呢
21     int i=0;
22     while(flag){
23         printf("main i=%d\n",i++);
24     }
25     printf("main bye bye\n");
26     return 0;
27 }

运行结果:

正如我们所想,在main线程中执行while循环,等到时间片用完了后,交出cpu有等待队列中的线程执行,然后fun执行完了,交给主线程main再执行。

总之:sleep函数的作用是让本线程睡眠挂起,交出cpu资源,让等待队列中的处于就绪状态的线程执行,在哪个线程中调用sleep就让哪个线程睡眠挂起。

鄙人之愚见,错误请指正。谢谢

 

抱歉!评论已关闭.