• ACE线程管理机制-并发控制(4)


    转载于:http://www.cnblogs.com/TianFang/archive/2006/12/04/581857.html

    ACE Synchronization类

    这一类并发控制对象一般也叫做杂项并发类,这类对象一般用得不多,这里我只是对其作一些简单的介绍。

    1.Atomic_Op类

    ACE_Atomic_Op类用于将同步透明地参数化进基本的算术运算中。

    ACE_Atomic_Op是一种模板类,锁定机制和需要参数化的类型被作为参数传入其中,重载所有算术操作符,并确保在操作前获取锁,在操作后释放它。运算本身被委托给通过模板传入的的类。

    使用ACE_Atomic_Op进行变量封装时,对于那些用ACE_Atomic_Op封装了的变量操作都变成了线程安全的,而并看不到显式的加解锁代码,代码变得更简洁,优雅。

       

    2.ACE中的栅栏(Barrier)

    一组线程可以使用栅栏来进行共同的相互同步。组中的每个线程各自执行,直到到达栅栏,就阻塞在那里。在所有相关线程到达栅栏后,它们就全部继续它们的执行。就是说,它们一个接一个地阻塞,等待其他的线程到达栅栏;一旦所有线程都到达了它们的执行路径中的"栅栏点",它们就一起重新启动。

    在ACE中,栅栏在ACE_Barrier类中实现。在栅栏对象被实例化时,它将要等待的线程的数目会作为参数传入。一旦到达执行路径中的"栅栏点",每个线程都在栅栏对象上发出wait()调用。它们在这里阻塞,直到其他线程到达它们各自的"栅栏点",然后再一起继续执行。当栅栏从相关线程那里接收了适当数目的wait()调用时,它就同时唤醒所有阻塞的线程。

    举个简单的例子,运动员进行赛跑比赛时,虽然他们到达终点有先后顺序,但会等到所有的运动员跑完比赛后才一起领奖。

  • 相关阅读:
    Maven3路程(一)用Maven创建第一个web项目(1)
    ECLIPSE下SVN的创建分支/合并/切换使用
    Oracle 客户端免安装数据库连接
    如何用Maven创建web项目(具体步骤)
    使用Eclipse构建Maven项目 (step-by-step)
    Maven安装配置
    动画基础(隐式动画)
    CA*Layer(CAReplicatorLayer--)
    CA*Layer(CATransformLayer--CAGradientLayer)
    CA*Layer(CAShapeLayer--CATextLayer)
  • 原文地址:https://www.cnblogs.com/shmilxu/p/4860418.html
Copyright © 2020-2023  润新知