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

  • 相关阅读:
    kubernetes架构部署
    GitLab+Jenkins+Ansible
    python之字典方法
    Python之列表方法
    python之字符串方法
    Python编写从ZabbixAPI获取信息
    Django基础
    扫描某个包下所有的类,输出所有使用了特定注解的类的注解值
    日志切面和统一异常处理
    Mybatis动态排序问题
  • 原文地址:https://www.cnblogs.com/Torstan/p/2700631.html
Copyright © 2011-2022 走看看