c线程中sleep()和pthread_join()函数之我见
线程之我见,有错误,请指正,谢谢
线程的执行需要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就让哪个线程睡眠挂起。
鄙人之愚见,错误请指正。谢谢