博客
关于我
C++11中静态局部变量初始化的线程安全性
阅读量:777 次
发布时间:2019-03-22

本文共 737 字,大约阅读时间需要 2 分钟。

C++11标准引入了对局部静态变量的线程安全性要求,使得实现线程安全的单例类变得非常简单。以下将深入分析这一实现方式,并探讨GCC如何在其实现中执行标准的要求。

局部静态变量的线程安全性机制在C++11标准中得到了详细描述。主要包括以下几个要点:

  • 变量在第一次访问时进行初始化,初始化完成后视为已完全;
  • 如在初始化过程中发生异常,视为未完成初始化,下一次访问时需重新初始化;
  • 当前线程在尝试初始化变量时,若其他线程正在初始化,当前线程会阻塞直到完成;
  • 若存在递归调用,则行为未定义。
  • 以一个例子来说明这个机制:

    class Foo {public:  static Foo *getInstance() {    static Foo s_instance;    return &s_instance;  private:    Foo() {}};

    该实现利用静态变量和C++11的线程支持机制,轻松获得线程安全的单例模式。

    GCC实现这一机制后,通过反汇编可以看到其如何配合C++运行时库(libsupc++)来实现线程安全。关键点包括:

  • 利用guard变量监控局部静态变量的初始化状态;
  • 使用__cxa_guard_acquire__cxa_guard_release来协调多个线程的行为。
  • 通过分析__cxa_guard_acquire函数的源码,可以看出它通过原子操作和futex系统调用确保线程安全。此外,当递归调用发生时,GCC在多线程环境下会导致死锁,而在单线程环境则会抛出异常,这正是C++11标准要求的处理方式。

    总的来说,线程安全的实现要求编程者严格遵守标准和语言的基础设施支持。如若需要自定义实现,建议借助现有库或框架,以避免复杂的底层管理工作。

    转载地址:http://crpwk.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置实例-反向代理实例:根据访问的路径跳转到不同端口的服务中
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    Nginx配置文件nginx.conf中文详解(总结)
    查看>>
    nginx配置详解、端口重定向和504
    查看>>
    Nginx配置负载均衡到后台网关集群
    查看>>
    Nginx配置限流,技能拉满!
    查看>>
    Nginx面试三连问:Nginx如何工作?负载均衡策略有哪些?如何限流?
    查看>>
    Nginx:NginxConfig可视化配置工具安装
    查看>>
    ngModelController
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>