zoukankan      html  css  js  c++  java
  • CRITICAL_SECTION

    CRITICAL_SECTION cs;

    InitializeCriticalSection(&cs);

    EnterCriticalSection(&cs);

    在这时,线程被认为「拥有」临界区域对象。两个线程不可以同时拥有同一个临界区域对象,因此,如果一个线程进入了临界区域,那么下一个使用同一临界区域对象呼叫EnterCriticalSection的线程将在函数呼叫中被暂停。只有当第一个线程通过下面的呼叫离开临界区域时,函数才会传回控制权: 

    LeaveCriticalSection (&cs) ;

    DeleteCriticalSection(&cs); 

    临界区域的一个限制是它们只能用于在同一程序内的线程之间的协调。但是在某些情况下,您需要协调两个不同程序对同一资源的共享(如共享内存等)。在此其况下不能使用临界区域,而需要用互斥对象。

    --

    hEvent = CreateEvent (&sa, fManual, fInitial, pszName) ; 

    第一个参数(指向一个SECURITY_ATTRIBUTES结构的指针)和最后一个参数(一个事件对象的名字)只有在事件对象被多个程序共享时才有意义。在同一程序中,这些参数通常被设定为NULL。

    如果您希望事件对象被初始化为有信号的,那么将fInitial参数设定为TRUE。

    而如果希望事件对象被初始化为无信号的,则将fInitial参数设定为FALSE。

    SetEvent (hEvent) ; 

    ResetEvent (hEvent) ; 

    WaitForSingleObject (hEvent, dwTimeOut) ; 

    如果最初的CreateEvent呼叫的fManual参数被设定为FALSE,那么事件对象将在WaitForSingleObject函数传回时自动重置。

    这种功能特性通常使得事件对象没有必要使用ResetEvent函数。
  • 相关阅读:
    c/c++设置图片为透明图
    转;说说AngularJS中的$parse和$eval
    转: css3: display:box详解
    转: 深入理解 AngularJS 的 Scope
    转:说说angularjs中的$parse和$eval
    转: 理解AngularJS中的依赖注入
    angularjs学习总结(快速预览版)
    XML基础知识
    读书笔记:js设计模式
    contains 和 ele.compareDocumentPosition确定html节点间的关系
  • 原文地址:https://www.cnblogs.com/mumuliang/p/2514744.html
Copyright © 2011-2022 走看看