zoukankan      html  css  js  c++  java
  • thread local storage

    Thread local storage allows multi-threaded applications to have a separate instance of a given data item for each thread. Where a single-threaded application would use static or global data, this could lead to contention, dead lock or data corruption in a multi-threaded application. One example is the C errno variable, used for storing the erro code related to functions from the Standard C library. It is common practice (and required by POSIX) for compliers that support multi-threaded applications to provide a separate instance of errno for each thread, in order to avoid different thread competing to read or update the value.

    related APIs in pthread.h.

    int pthread_key_create(pthread_key_t *key, void (*destructor)(void *));
    Returns 0 on success, or a positive error number on error

    int pthread_key_delete(pthread_key_t key);

    If successful, the pthread_key_delete() function shall return zero; otherwise, an error number shall be returned to indicate the error.

    int pthread_setspecific(pthread_key_t key, const void *value);
    Returns 0 on success, or a positive error number on error

    void *pthread_getspecific(pthread_key_t key);
    Returns pointer, or NULL if no thread-specific data isassociated with key

     

    references:

    Linux programming interface

  • 相关阅读:
    人件阅读笔记之三
    明日计划:团队开发Fooks第十天
    明日计划:团队开发Fooks第九天
    明日计划:团队开发Fooks第八天
    明日计划:团队开发Fooks第七天
    明日计划:团队开发Fooks第六天
    优先队列
    KMP
    django-中间件
    Ajax--参数,csrf跨站请求伪造,serialize(),上传文件formdata
  • 原文地址:https://www.cnblogs.com/Torstan/p/2700631.html
Copyright © 2011-2022 走看看