与线程相关的说明
һpthread_t
pthread_t在头文件/usr/include/bits/pthreadtypes.h中定义:
typedef unsigned long int pthread_t;
它是一个线程标识符.
两个pthread_create
函数pthread_create用于创建线程,其原型为:
extern int pthread_create __P((pthread_t * __ thread,__const pthread_attr_t * __ attr,
无效*(* __ start_routine)(无效*),无效* __ arg));
第一个参数是指向线程标识符的指针,第二个参数用于设置线程属性,第三个参数是线程运行函数的起始地址,最后一个参数是运行函数的参数. 在这里,我们的函数线程不需要任何参数,因此最后一个参数设置为空指针. 我们还将第二个参数设置为空指针,这将生成具有默认属性的线程. 在下一节中,我们将详细介绍线程属性的设置和修改. 成功创建线程后,该函数返回0. 如果不为0,则意味着线程创建失败. 常见的错误返回码是EAGAIN和EINVAL. 前者表明系统限制了新线程的创建,例如c同时启动多个pthread,线程太多;后者表示第一个. 由两个参数表示的线程属性值是非法的. 成功创建线程后,新创建的线程将运行由参数三和参数四确定的功能,而原始线程将继续运行下一行代码.
三个pthread_join pthread_exit
函数pthread_join用于等待线程结束. 函数原型为:
extern int pthread_join __P((pthread_t __th,void ** __ thread_return));
第一个参数是等待线程的标识符,第二个参数是用户定义的指针,可用于存储等待线程的返回值. 该功能是线程阻塞功能. 调用它的函数将等待,直到等待线程结束. 当函数返回时,将恢复等待线程的资源. 结束线程有两种方法. 一个是,就像上面的示例一样,函数结束,并且调用它的线程结束. 另一种方法是通过函数pthread_exit.
其功能原型为:
extern void pthread_exit __P((void * __ retval))__attribute__((__noreturn __));
唯一的参数是函数的返回码,只要pthread_join中的第二个参数thread_return不为NULL,该值就会传递给thread_return. 最后要注意的是,一个线程不能被多个线程等待,否则,第一个成功接收到信号的线程将返回,而其余名为pthread_join的线程将返回错误代码ESRCH.
在本节中,我们编写了最简单的线程,并掌握了三个最常用的函数pthread_createc同时启动多个pthread,pthread_join和pthread_exit. 下面,让我们了解线程的一些常见属性以及如何设置这些属性.
与互斥锁有关
互斥锁用于确保一段时间内只有一个线程正在执行一段代码.
һpthread_mutex_init
函数pthread_mutex_init用于生成互斥量. NULL参数指示使用默认属性. 如果需要声明特定的属性互斥锁,则必须调用函数pthread_mutexattr_init. 函数pthread_mutexattr_setpshared和函数pthread_mutexattr_settype用于设置互斥锁的属性. 上一个函数设置属性pshared,该属性具有两个值PTHREAD_PROCESS_PRIVATE和PTHREAD_PROCESS_SHARED. 前者用于同步不同进程中的线程,后者用于同步进程中的不同线程. 在上面的示例中,我们使用默认属性PTHREAD_PROCESS_ PRIVATE. 后者用于设置互斥锁的类型,可选类型为PTHREAD_MUTEX_NORMAL,PTHREAD_MUTEX_ERRORCHECK,PTHREAD_MUTEX_RECURSIVE和PTHREAD _MUTEX_DEFAULT. 它们分别定义了不同的上下解锁机制. ,通常选择最后一个默认属性.
两个pthread_mutex_lock pthread_mutex_unlock pthread_delay_np
pthread_mutex_lock语句开始使用互斥锁进行锁定. 之后,代码被锁定,直到调用pthread_mutex_unlock,即一次只能由一个线程调用和执行. 当一个线程执行到pthread_mutex_lock时,如果此时该锁被另一个线程使用,则该线程被阻塞,即程序将等待,直到另一个线程释放该互斥锁.
这里是一个例子. 我们通过创建两个线程来实现数字的增量.
#include
#include
#include
#include
#define MAX 10
pthread_t thread[2];
pthread_mutex_t mut;
int number=0, i;
void *thread1()
{
printf ("thread1 : I'm thread 1\n");
for (i = 0; i < MAX; i++)
{
printf("thread1 : number = %d\n",number);
pthread_mutex_lock(&mut);
number++;
pthread_mutex_unlock(&mut);
sleep(2);
}
printf("thread1 :主函数在等我完成任务吗?\n");
pthread_exit(NULL);
}
void *thread2()
{
printf("thread2 : I'm thread 2\n");
for (i = 0; i < MAX; i++)
{
printf("thread2 : number = %d\n",number);[nextpage]
pthread_mutex_lock(&mut);
number++;
pthread_mutex_unlock(&mut);
sleep(3);
}
printf("thread2 :主函数在等我完成任务吗?\n");
pthread_exit(NULL);
}
void thread_create(void)
{
int temp;
memset(&thread, 0, sizeof(thread)); //comment1
/*创建线程*/
if((temp = pthread_create(&thread[0], NULL, thread1, NULL)) != 0) //comment2
printf("线程1创建失败!\n");
else
printf("线程1被创建\n");
if((temp = pthread_create(&thread[1], NULL, thread2, NULL)) != 0) //comment3
printf("线程2创建失败");
else
printf("线程2被创建\n");
}
void thread_wait(void)
{
/*等待线程结束*/
if(thread[0] !=0) { //comment4
pthread_join(thread[0],NULL);
printf("线程1已经结束\n");
}
if(thread[1] !=0) { //comment5
pthread_join(thread[1],NULL);
printf("线程2已经结束\n");
}
}
int main()
{
/*用默认属性初始化互斥锁*/
pthread_mutex_init(&mut,NULL);
printf("我是主函数哦,我正在创建线程,呵呵\n");
thread_create();
printf("我是主函数哦,我正在等待线程完成任务阿,呵呵\n");
thread_wait();
return 0;
}
让我们先编译并执行
报价:
falcon @ falcon: 〜/ program / c / code / ftp $ gcc -lpthread -o thread_example thread_example.c
falcon @ falcon: 〜/ program / c / code / ftp $ ./thread_example
我是主要功能,我正在创建一个线程,呵呵
线程1已创建
创建线程2
我是主要功能,我正在等待线程完成任务,呵呵
线程1: 我是线程1
线程1: 数字= 0
线程2: 我是线程2
线程2: 数字= 1
线程1: 数字= 2
thread2: 数字= 3
线程1: 数字= 4
线程2: 数字= 5
线程1: 数字= 6
线程1: 数字= 7
线程2: 数字= 8
线程1: 数字= 9
thread2: 数字= 10
线程1: 主要功能正在等待我完成任务吗?
线程1已经结束
thread2: 主要功能正在等待我完成任务吗?
线程2已结束
上面对C语言多线程pthread库的相关功能的描述是我与您共享的所有内容. 我希望能给您参考,也希望您能支持该脚本主页.
本文来自电脑杂谈,转载请注明本文网址:
http://www.pc-/a/jisuanjixue/article-257271-1.html