这篇文章主要讲解了linux中pthread_create的使用方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
函数简介
pthread_create是UNIX环境创建线程函数
头文件
# include
函数声明
int pthread_create (pthread_t *限制tidp, const pthread_attr_t * restrict_attr, void * (* start_rtn) (void *), void *限制arg);
返回值
若成功则返回0,否则返回出错编号
参数
第一个参数为指向线程标识符的指针。
第二个参数用来设置线程属性。
第三个参数是线程运行函数的地址。
最后一个参数是运行函数的参数。
注意
在编译时注意加上-lpthread参数,以调用静态链接库。因为pthread并非linux系统的默认库。
函数简介
函数pthread_join用来等待一个线程的结束。
函数原型为:
extern int pthread_join __P (pthread_t __th, void * * __thread_return);
参数:
第一个参数为被等待的线程标识符
第二个参数为一个用户定义的指针,它可以用来存储被等待线程的返回值。
注意
,,,这个函数是一个线程阻塞的函数,调用它的函数将一直等待到被等待的线程结束为止,当函数返回时,被等待线程的资源被收回。如果执行成功,将返回0,如果失败则返回一个错误号。
例子:
# include# include # include /*声明结构体*/结构体成员 { int num; char *名称; };/*定义线程pthread */静态void * pthread (void *参数) { 结构体成员*温度;/*线程pthread开始运行*/printf (“pthread开始! \ n");/*令主线程继续执行*/睡眠(2);/*打印传入参数*/temp=(结构体成员*)参数; printf(“成员→num: % d \ n",临时→num); printf(“成员→名称:% s \ n",临时→名称); 返回NULL; }/*主函数*/int主要(int agrc, char * argv []) { pthread_t tidp; 结构体成员* b;/*为结构体变量b赋值*/b=(*)结构体成员malloc (sizeof (struct成员)); b→num=1; b→name=癿lq";/*创建线程pthread */如果((pthread_create(和tidp, NULL, pthread, (void *) b))==1) { printf(“创建错误! \ n"); 返回1; }/*令线程pthread先运行*/睡眠(1);/*线程pthread睡眠2 s,此时主要可以先执行*/printf(“面继续! \ n");/*等待线程pthread释放*/如果(pthread_join (tidp, NULL)) { printf(“线程不是退出…\ n"); 返回2; } 返回0; }
编译与执行结果
,,,编译与执行结果如下图所示,可以看到主线程主要和线程pthread交替执行。也就是说是当我们创建了线程pthread之后,两个线程都在执行,证明创建成功。另外,可以看到创建线程pthread时候,传入的参数被正确打印。
看完上述内容,是不是对linux中pthread_create的使用方法有进一步的了解,如果还想学习更多内容,欢迎关注行业资讯频道。