multithreading - 通过计数测试信号量

标签 multithreading semaphore

有一个article about semaphores on OS X。作者通过在两个线程中递增和递减静态变量来测试信号量。在信号量保护变量访问的情况下,变量最终为零。如果没有后卫,变量最终将具有虚假值。我尝试了代码,它可以工作。我不了解的是,来自两个线程的并发访问如何使最终变量值有所不同。毕竟,在我看来,一堆+1和–1应该是可交换的,对吗?我觉得我缺少明显的东西,那是什么? :)

最佳答案

问题在于++/--不是原子的。它们本质上是三个操作:

  • 加载
  • Inc/dec
  • 商店

  • 因此,如果两个线程同时加载值并同时存储它。差异将是1而不是2。

    这是 sample
    Thread A Thread B
    Load 5   Load 5
    Inc 6    Inc 6
    Store 6  Store 6
    

    关于multithreading - 通过计数测试信号量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3896952/

    相关文章:

    android - 等到 fragment 被添加到 UI

    c - 信号量和共享内存

    c - 为什么我的这段代码会出现段错误?

    C信号量生产者消费者临界区

    php - 在 RAII 中删除共享内存和信号量的正确策略,如 php 类

    c 信号量和共享内存操作计数器

    c - 如何并行运行该函数?

    Java并发: Modifying latch/ThreadGroup to achieve Executor behaviour

    python - 让 CherryPy 在收到键盘中断后立即退出?

    java - 线程停放在 java.util.concurrent.ThreadPoolExecutor.getTask 的原因可能是什么