Linux多线程编程的基本的函数

合集下载

linux pthread_create 参数

linux pthread_create 参数

linux pthread_create 参数Linux线程的创建是一个非常重要的话题,因为线程是一个应用程序中最基本的实体之一。

Linux中的线程是使用POSIX线程库(Pthread)实现的。

该库使得在Linux系统中使用线程非常方便。

本文将介绍Pthread库中的pthead_create()函数及其参数。

pthread_create() 函数原型:``` int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void*(*start_routine) (void *), void *arg); ```pthread_create 函数接受四个参数1.参数(thread): 指向pthread_t类型的指针,用来保存线程ID。

2.参数(attr): 指向 pthread_attr_t 类型的指针,用于设置线程的属性。

通常设置为NULL,使用默认属性。

3.参数(start_routine): 线程函数指针,该函数必须接受一个(void *)类型的参数,并返回一个(void *)类型的指针。

4.参数(arg): 传递给线程函数(start_routine)的参数。

线程创建完成后,它会执行调用 pthread_create() 函数的进程中的start_routine()函数,并将传递给pthread_create() 函数的参数(arg)传递给start_routine()函数。

以下是本函数传入的参数的详细说明。

1.参数(thread)参数thread是一个指针类型的变量,用来保存线程的ID。

在进程中创建一个线程时,线程的ID将存储在此指针中。

这个参数是必需的。

2.参数(attr)参数attr是一个指向pthread_attr_t类型结构体的指针。

pthread_attr_t是Linux系统中线程的属性类型,这个结构体包含了很多控制线程性质的变量,比如优先级,调度策略等等。

Unix_Linux_Windows_OpenMP多线程编程

Unix_Linux_Windows_OpenMP多线程编程

Unix_Linux_Windows_OpenMP多线程编程第三章 Unix/Linux 多线程编程[引言]本章在前面章节多线程编程基础知识的基础上,着重介绍 Unix/Linux 系统下的多线程编程接口及编程技术。

3.1 POSIX 的一些基本知识POSIX 是可移植操作系统接口(Portable Operating SystemInterface)的首字母缩写。

POSIX 是基于 UNIX 的,这一标准意在期望获得源代码级的软件可移植性。

换句话说,为一个 POSIX 兼容的操作系统编写的程序,应该可以在任何其它的 POSIX 操作系统(即使是来自另一个厂商)上编译执行。

POSIX 标准定义了操作系统应该为应用程序提供的接口:系统调用集。

POSIX是由 IEEE(Institute of Electrical andElectronic Engineering)开发的,并由 ANSI(American National Standards Institute)和 ISO(International StandardsOrganization)标准化。

大多数的操作系统(包括 Windows NT)都倾向于开发它们的变体版本与 POSIX 兼容。

POSIX 现在已经发展成为一个非常庞大的标准族,某些部分正处在开发过程中。

表 1-1 给出了 POSIX 标准的几个重要组成部分。

POSIX 与 IEEE 1003 和 2003 家族的标准是可互换的。

除 1003.1 之外,1003 和 2003 家族也包括在表中。

管理 POSIX 开放式系统环境(OSE) 。

IEEE 在 1995 年通过了这项标准。

ISO 的1003.0版本是 ISO/IEC 14252:1996。

被广泛接受、用于源代码级别的可移植性标准。

1003.1 提供一个操作系统的C 语1003.1 言应用编程接口(API) 。

IEEE 和 ISO 已经在 1990 年通过了这个标准,IEEE 在1995 年重新修订了该标准。

linux多线程 pthread常用函数详解

linux多线程 pthread常用函数详解

linux多线程pthread常用函数详解Linux多线程是指在Linux操作系统中运行的多个线程。

线程是执行程序的基本单位,它独立于其他线程而存在,但共享相同的地址空间。

在Linux中,我们可以使用pthread库来实现多线程程序。

本文将详细介绍pthread库中常用的函数,包括线程的创建、退出、同步等。

一、线程创建函数1. pthread_create函数pthread_create函数用于创建一个新线程。

其原型如下:cint pthread_create(pthread_t *thread, const pthread_attr_t *attr, void*(*start_routine) (void *), void *arg);参数说明:- thread:用于存储新线程的ID- attr:线程的属性,通常为NULL- start_routine:线程要执行的函数地址- arg:传递给线程函数的参数2. pthread_join函数pthread_join函数用于等待一个线程的结束。

其原型如下:int pthread_join(pthread_t thread, void retval);参数说明:- thread:要等待结束的线程ID- retval:用于存储线程的返回值3. pthread_detach函数pthread_detach函数用于将一个线程设置为分离状态,使其在退出时可以自动释放资源。

其原型如下:cint pthread_detach(pthread_t thread);参数说明:- thread:要设置为分离状态的线程ID二、线程退出函数1. pthread_exit函数pthread_exit函数用于退出当前线程,并返回一个值。

其原型如下:cvoid pthread_exit(void *retval);参数说明:- retval:线程的返回值2. pthread_cancel函数pthread_cancel函数用于取消一个线程的执行。

linux原子操作函数

linux原子操作函数

linux原子操作函数Linux原子操作函数是一组用于实现多线程同步和互斥的函数。

在并发编程中,多个线程同时访问共享资源时,可能会导致数据的不一致或竞争条件的发生。

原子操作函数可以保证多线程之间的顺序性和一致性,从而避免了竞争条件的产生。

原子操作函数的特点是不可分割和不可中断,即在执行原子操作期间,不会被其他线程打断或者分割成多个步骤执行。

这种特性保证了原子操作的完整性,使多线程之间可以安全地共享资源。

Linux提供了多个原子操作函数,其中最常用的有以下几个:1. atomic_inc(原子增加):该函数用于对指定的整型变量进行原子递增操作。

它保证了递增操作的完整性,不会被其他线程打断或者分割成多个步骤执行。

该函数常用于实现计数器等功能。

2. atomic_dec(原子减少):与atomic_inc函数类似,该函数用于对指定的整型变量进行原子递减操作。

同样地,它也保证了递减操作的完整性。

3. atomic_add(原子加法):该函数用于对指定的整型变量进行原子加法操作。

它可以将一个给定的值原子地加到指定的变量上,保证了整个加法操作的完整性和一致性。

4. atomic_sub(原子减法):与atomic_add函数类似,该函数用于对指定的整型变量进行原子减法操作。

它可以将一个给定的值原子地从指定的变量上减去。

5. atomic_xchg(原子交换):该函数用于原子地交换两个指定的值。

它可以保证交换操作的完整性,不会被其他线程打断。

6. atomic_cmpxchg(原子比较并交换):该函数用于比较指定的变量的值与给定的期望值是否相等,如果相等则用新的值替换旧的值。

它是一种常用的原子操作,可以用于实现互斥锁等功能。

除了上述常用的原子操作函数外,Linux还提供了其他一些原子操作函数,如atomic_and、atomic_or、atomic_xor等,它们分别用于进行按位与、按位或和按位异或的原子操作。

linux interlockedincrement

linux interlockedincrement

linux interlockedincrement题目:Linux下的InterlockedIncrement函数及其应用引言:在多线程编程中,为了确保对共享资源的访问安全,我们需要使用同步机制来实现线程间的互斥访问。

而Linux提供了一系列的原子操作函数,其中之一就是InterlockedIncrement函数。

本文将详细介绍Linux下的InterlockedIncrement函数的使用方法以及其在多线程环境下的应用。

第一部分:InterlockedIncrement函数的概述(200-300字)InterlockedIncrement函数是Linux内核提供的原子操作函数之一,用于对变量进行原子递增操作。

它能够保证在多线程环境下,对共享资源的访问是互斥的,不会出现数据竞争的问题。

该函数的原型为“__attribute__((always_inline)) int32_tInterlockedIncrement(int32_t* addend)”。

其中,参数“addend”是一个指向要增加的变量的指针。

第二部分:InterlockedIncrement函数的使用方法(300-400字)1. 头文件引用要在程序中使用InterlockedIncrement函数,需要包含<linux/interrupt.h>头文件。

2. 函数调用在需要进行原子递增操作的地方,调用InterlockedIncrement函数即可。

例如:“InterlockedIncrement(&counter);”3. 返回值InterlockedIncrement函数会返回递增后的变量值。

第三部分:InterlockedIncrement函数的示例代码(400-500字)为了更好地理解InterlockedIncrement函数的使用方法,下面给出一个简单的示例代码。

c#include <linux/interrupt.h>#include <pthread.h>#include <stdio.h>int counter = 0;void* threadFunc(void* arg) {for (int i = 0; i < 100000; ++i) {InterlockedIncrement(&counter);}return NULL;}int main() {pthread_t thread1, thread2;pthread_create(&thread1, NULL, threadFunc, NULL);pthread_create(&thread2, NULL, threadFunc, NULL);pthread_join(thread1, NULL);pthread_join(thread2, NULL);printf("Final count: d\n", counter);return 0;}上述代码中,我们创建了两个线程,每个线程都会调用threadFunc函数来递增counter变量的值。

linux下的CC++多进程多线程编程实例详解

linux下的CC++多进程多线程编程实例详解

linux下的CC++多进程多线程编程实例详解linux下的C\C++多进程多线程编程实例详解1、多进程编程#include <stdlib.h>#include <sys/types.h>#include <unistd.h>int main(){pid_t child_pid;/* 创建⼀个⼦进程 */child_pid = fork();if(child_pid == 0){printf("child pid\n");exit(0);}else{printf("father pid\n");sleep(60);}return 0;}2、多线程编程#include <stdio.h>#include <pthread.h>struct char_print_params{char character;int count;};void *char_print(void *parameters){struct char_print_params *p = (struct char_print_params *)parameters;int i;for(i = 0; i < p->count; i++){fputc(p->character,stderr);}return NULL;}int main(){pthread_t thread1_id;pthread_t thread2_id;struct char_print_params thread1_args;struct char_print_params thread2_args;thread1_args.character = 'x';thread1_args.count = 3000;pthread_create(&thread1_id, NULL, &char_print, &thread1_args);thread2_args.character = 'o';thread2_args.count = 2000;pthread_create(&thread2_id, NULL, &char_print, &thread2_args);pthread_join(thread1_id, NULL);pthread_join(thread2_id, NULL);return 0;}3、线程同步与互斥1)、互斥pthread_mutex_t mutex;pthread_mutex_init(&mutex, NULL);/*也可以⽤下⾯的⽅式初始化*/pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; pthread_mutex_lock(&mutex);/* 互斥 */thread_flag = value;pthread_mutex_unlock(&mutex);2)、条件变量int thread_flag = 0;pthread_mutex_t mutex;pthread_cond_t thread_flag_cv;\void init_flag(){pthread_mutex_init(&mutex, NULL);pthread_cond_init(&thread_flag_cv, NULL);thread_flag = 0;}void *thread_function(void *thread_flag){while(1){pthread_mutex_lock(&mutex);while(thread_flag != 0 ){pthread_cond_wait(&thread_flag_cv, &mutex);}pthread_mutex_unlock(&mutex);do_work();}return NULL;}void set_thread_flag(int flag_value){pthread_mutex_lock(&mutex);thread_flag = flag_value;pthread_cond_signal(&thread_flag_cv);pthread_mutex_unlock(&mutex);}感谢阅读,希望能帮助到⼤家,谢谢⼤家对本站的⽀持!。

Linux下多线程编程-Pthread与Semaphore的使用

Linux下多线程编程-Pthread与Semaphore的使用

简单的多线程编程Linux系统下的多线程遵循POSIX线程接口,称为pthread。

编写Linux下的多线程程序,需要使用头文件pthread.h,连接时需要使用库libpthread.a。

顺便说一下,Linux下pthread的实现是通过系统调用clone()来实现的。

clone ()是Linux所特有的系统调用,它的使用方式类似fork,关于clone()的详细情况,有兴趣的读者可以去查看有关文档说明。

下面我们展示一个最简单的多线程程序 example1.c。

/* example.c*/#include <stdio.h>#include <pthread.h>void thread(void){int i;for( i = 0;i < 3; i++ )printf("This is a pthread.\n");}int main(void){pthread_t id;int i,ret;ret = pthread_create( &id, NULL, (void *)thread, NULL );if ( ret!=0 ) {printf ("Create pthread error!\n");exit (1);}for( i = 0; i < 3; i++ )printf("This is the main process.\n");pthread_join(id,NULL);return (0);}我们编译此程序:gcc example1.c -lpthread -o example1运行example1,我们得到如下结果:This is the main process.This is a pthread.This is the main process.This is the main process.This is a pthread.This is a pthread.再次运行,我们可能得到如下结果:This is a pthread.This is the main process.This is a pthread.This is the main process.This is a pthread.This is the main process.前后两次结果不一样,这是两个线程争夺CPU资源的结果。

Linux系统线程创建及同步互斥方法简要说明(供查考)

Linux系统线程创建及同步互斥方法简要说明(供查考)

Linux系统线程创建及同步互斥方法简要说明(供查考)1、.POSIX线程函数的定义在头文件pthread.h中,所有的多线程程序都必须通过使用#include<pthread.h>包含这个头文件2、用gcc编译多线程程序时,必须与pthread函数库连接。

可以使用以下两种方式编译(建议使用第一种)(1)gcc –D_REENTRANT -o 编译后的目标文件名源文件名-lpthread例如:gcc –D_REENTRANT -o pthread_create pthread_create.c -lpthread (执行该编译结果的方式为:./pthread_create)(2)gcc -pthread -o 编译后的文件名源文件名例如:gcc -pthread -o example example.c一、需要用到的函数的用法提示1、创建线程函数pthread_t a_thread; /*声明a_thread变量,用来存放创建的新线程的线程ID(线程标识符)*/int res=pthread_create(&a_thread,NULL,thread_function,NULL);/*创建一个执行函数thread_function的新线程,线程ID存放在变量a_thread */ 2、退出线程函数pthread_exit(NULL);/*那个线程在执行中调用了该方法,那个线程就退出*/创建和退出线程实例3、连接(等待)线程函数int error;int *exitcodeppthread_t tid; /*用来表示一个已经存在的线程*/error=pthread_join(tid,&exitcodep); /*执行该方法的线程将要一直等待,直到tid 表示的线程执行结束,exitcodep 存放线程tid退出时的返回值*/4、返回线程ID的函数pthread_t t/*声明表示线程的变量t */t=pthread_self( ) /*返回调用该方法的线程的线程ID*/5、判断两个线程是否相等的函数(pthread_equal)int pthread_equal(pthread_t t1, pthread_t t2);/*判断线程t1与线程t2是否线程ID相等*/二、线程同步1、使用互斥量同步线程(实现互斥)(1)互斥量的创建和初始化pthread_mutex_t a_mutex=PTHREAD_MUTEX_INITIALIZER/*声明a_mutex为互斥量,并且初始化为PTHREAD_MUTEX_INITIALIZER */ (2)锁定和解除锁定互斥量pthread_mutex_t a_mutex=PTHREAD_MUTEX_INITIALIZER/*声明互斥量a_mutex*/int rc=pthread_mutex_lock(&a_mutex) /*锁定互斥量a_mutex*/ ………………………………/*锁定后的操作*/int rd= pthread_mutex_unlock(&a_mutex) /*解除对互斥量a_mutex的锁定*/例子:利用互斥量来保护一个临界区pthread_mutex_t a_mutex=PTHREAD_MUTEX_INITIALIZER;pthread_mutex_lock(&a_mutex) /*锁定互斥量a_mutex*//*临界区资源*/pthread_mutex_unlock(&a_mutex) /*解除互斥量a_mutex的锁定*/(3)销毁互斥量Int rc=pthread_mutex_destory(&a_mutex) /*销毁互斥量a_mutex*/2、用条件变量同步线程(实现真正的同步)条件变量是利用线程间共享的全局变量进行同步的一种机制,主要包括两个动作:一个线程等待"条件变量的条件成立"而挂起;另一个线程使"条件成立"(给出条件成立信号)。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Posix线程编程指南(一)线程创建与取消这是一个关于Posix线程编程的专栏。

作者在阐明概念的基础上,将向您详细讲述Posix线程库API。

本文是第一篇将向您讲述线程的创建与取消。

线程创建1.1 线程与进程相对进程而言,线程是一个更加接近于执行体的概念,它可以与同进程中的其他线程共享数据,但拥有自己的栈空间,拥有独立的执行序列。

在串行程序基础上引入线程和进程是为了提高程序的并发度,从而提高程序运行效率和响应时间。

线程和进程在使用上各有优缺点:线程执行开销小,但不利于资源的管理和保护;而进程正相反。

同时,线程适合于在SMP机器上运行,而进程则可以跨机器迁移。

1.2 创建线程POSIX通过pthread_create()函数创建线程,API定义如下:与fork()调用创建一个进程的方法不同,pthread_create()创建的线程并不具备与主线程(即调用pthread_create()的线程)同样的执行序列,而是使其运行start_routine(arg)函数。

thread返回创建的线程ID,而attr是创建线程时设置的线程属性(见下)。

pthread_create()的返回值表示线程创建是否成功。

尽管arg是void *类型的变量,但它同样可以作为任意类型的参数传给start_routine()函数;同时,start_routine()可以返回一个void *类型的返回值,而这个返回值也可以是其他类型,并由pthread_join()获取。

1.3 线程创建属性pthread_create()中的attr参数是一个结构指针,结构中的元素分别对应着新线程的运行属性,主要包括以下几项:__detachstate,表示新线程是否与进程中其他线程脱离同步,如果置位则新线程不能用pthread_join()来同步,且在退出时自行释放所占用的资源。

缺省为PTHREAD_CREATE_JOINABLE状态。

这个属性也可以在线程创建并运行以后用pthread_detach()来设置,而一旦设置为PTHREAD_CREATE_DETACH状态(不论是创建时设置还是运行时设置)则不能再恢复到PTHREAD_CREATE_JOINABLE状态。

__schedpolicy,表示新线程的调度策略,主要包括SCHED_OTHER(正常、非实时)、SCHED_RR(实时、轮转法)和SCHED_FIFO(实时、先入先出)三种,缺省为SCHED_OTHER,后两种调度策略仅对超级用户有效。

运行时可以用过pthread_setschedparam()来改变。

__schedparam,一个struct sched_param结构,目前仅有一个sched_priority整型变量表示线程的运行优先级。

这个参数仅当调度策略为实时(即SCHED_RR或SCHED_FIFO)时才有效,并可以在运行时通过pthread_setschedparam()函数来改变,缺省为0。

__inheritsched,有两种值可供选择:PTHREAD_EXPLICIT_SCHED和PTHREAD_INHERIT_SCHED,前者表示新线程使用显式指定调度策略和调度参数(即attr中的值),而后者表示继承调用者线程的值。

缺省为PTHREAD_EXPLICIT_SCHED。

__scope,表示线程间竞争CPU的范围,也就是说线程优先级的有效范围。

POSIX的标准中定义了两个值:PTHREAD_SCOPE_SYSTEM和PTHREAD_SCOPE_PROCESS,前者表示与系统中所有线程一起竞争CPU时间,后者表示仅与同进程中的线程竞争CPU。

目前LinuxThreads仅实现了PTHREAD_SCOPE_SYSTEM一值。

pthread_attr_t结构中还有一些值,但不使用pthread_create()来设置。

为了设置这些属性,POSIX定义了一系列属性设置函数,包括pthread_attr_init()、pthread_attr_destroy()和与各个属性相关的pthread_attr_get---/pthread_attr_set---函数。

1.4 线程创建的Linux实现我们知道,Linux的线程实现是在核外进行的,核内提供的是创建进程的接口do_fork()。

内核提供了两个系统调用__clone()和fork(),最终都用不同的参数调用do_fork()核内API。

当然,要想实现线程,没有核心对多进程(其实是轻量级进程)共享数据段的支持是不行的,因此,do_fork()提供了很多参数,包括CLONE_VM(共享内存空间)、CLONE_FS(共享文件系统信息)、CLONE_FILES(共享文件描述符表)、CLONE_SIGHAND(共享信号句柄表)和CLONE_PID(共享进程ID,仅对核内进程,即0号进程有效)。

当使用fork系统调用时,内核调用do_fork()不使用任何共享属性,进程拥有独立的运行环境,而使用pthread_create()来创建线程时,则最终设置了所有这些属性来调用__clone(),而这些参数又全部传给核内的do_fork(),从而创建的"进程"拥有共享的运行环境,只有栈是独立的,由__clone()传入。

Linux线程在核内是以轻量级进程的形式存在的,拥有独立的进程表项,而所有的创建、同步、删除等操作都在核外pthread库中进行。

pthread库使用一个管理线程(__pthread_manager(),每个进程独立且唯一)来管理线程的创建和终止,为线程分配线程ID,发送线程相关的信号(比如Cancel),而主线程(pthread_create())的调用者则通过管道将请求信息传给管理线程。

线程取消2.1 线程取消的定义一般情况下,线程在其主体函数退出的时候会自动终止,但同时也可以因为接收到另一个线程发来的终止(取消)请求而强制终止。

2.2 线程取消的语义线程取消的方法是向目标线程发Cancel信号,但如何处理Cancel信号则由目标线程自己决定,或者忽略、或者立即终止、或者继续运行至Cancelation-point(取消点),由不同的Cancelation状态决定。

线程接收到CANCEL信号的缺省处理(即pthread_create()创建线程的缺省状态)是继续运行至取消点,也就是说设置一个CANCELED状态,线程继续运行,只有运行至Cancelation-point的时候才会退出。

2.3 取消点根据POSIX标准,pthread_join()、pthread_testcancel()、pthread_cond_wait()、pthread_cond_timedwait()、sem_wait()、sigwait()等函数以及read()、write()等会引起阻塞的系统调用都是Cancelation-point,而其他pthread函数都不会引起Cancelation动作。

但是pthread_cancel的手册页声称,由于LinuxThread库与C库结合得不好,因而目前C库函数都不是Cancelation-point;但CANCEL信号会使线程从阻塞的系统调用中退出,并置EINTR错误码,因此可以在需要作为Cancelation-point 的系统调用前后调用pthread_testcancel(),从而达到POSIX标准所要求的目标,即如下代码段:2.4 程序设计方面的考虑如果线程处于无限循环中,且循环体内没有执行至取消点的必然路径,则线程无法由外部其他线程的取消请求而终止。

因此在这样的循环体的必经路径上应该加入pthread_testcancel()调用。

2.5 与线程取消相关的pthread函数int pthread_cancel(pthread_t thread)发送终止信号给thread线程,如果成功则返回0,否则为非0值。

发送成功并不意味着thread会终止。

int pthread_setcancelstate(int state, int *oldstate)设置本线程对Cancel信号的反应,state有两种值:PTHREAD_CANCEL_ENABLE(缺省)和PTHREAD_CANCEL_DISABLE,分别表示收到信号后设为CANCLED状态和忽略CANCEL信号继续运行;old_state如果不为NULL则存入原来的Cancel状态以便恢复。

int pthread_setcanceltype(int type, int *oldtype)设置本线程取消动作的执行时机,type由两种取值:PTHREAD_CANCEL_DEFFERED和PTHREAD_CANCEL_ASYCHRONOUS,仅当Cancel状态为Enable时有效,分别表示收到信号后继续运行至下一个取消点再退出和立即执行取消动作(退出);oldtype如果不为NULL则存入运来的取消动作类型值。

void pthread_testcancel(void)检查本线程是否处于Canceld状态,如果是,则进行取消动作,否则直接返回。

Posix线程编程指南(二)线程创建与取消这是一个关于Posix线程编程的专栏。

作者在阐明概念的基础上,将向您详细讲述Posix线程库API。

本文是第二篇将向您讲述线程的私有数据。

概念及作用在单线程程序中,我们经常要用到"全局变量"以实现多个函数间共享数据。

在多线程环境下,由于数据空间是共享的,因此全局变量也为所有线程所共有。

但有时应用程序设计中有必要提供线程私有的全局变量,仅在某个线程中有效,但却可以跨多个函数访问,比如程序可能需要每个线程维护一个链表,而使用相同的函数操作,最简单的办法就是使用同名而不同变量地址的线程相关数据结构。

这样的数据结构可以由Posix线程库维护,称为线程私有数据(Thread-specific Data,或TSD)。

创建和注销Posix定义了两个API分别用来创建和注销TSD:该函数从TSD池中分配一项,将其值赋给key供以后访问使用。

如果destr_function不为空,在线程退出(pthread_exit())时将以key所关联的数据为参数调用destr_function(),以释放分配的缓冲区。

不论哪个线程调用pthread_key_create(),所创建的key都是所有线程可访问的,但各个线程可根据自己的需要往key中填入不同的值,这就相当于提供了一个同名而不同值的全局变量。

在LinuxThreads的实现中,TSD池用一个结构数组表示:创建一个TSD就相当于将结构数组中的某一项设置为"in_use",并将其索引返回给*key,然后设置destructor函数为destr_function。

相关文档
最新文档