zoukankan      html  css  js  c++  java
  • C++ CRITICAL_SECTION 临界区

    个人感觉这临界区相当于java 中的sy 关键字那种 相当于重度锁吧 加锁之后 只允许本线程读写 其他线程读都不能 效率有点低

    类似于 你上厕所锁门 别人就进不来 其他人想要使用时没法使用等你出来了才可以使用


    typedef struct _RTL_CRITICAL_SECTION {
    PRTL_CRITICAL_SECTION_DEBUG DebugInfo;
    LONG LockCount;
    LONG RecursionCount;
    HANDLE OwningThread;
    HANDLE LockSemaphore;
    DWORD SpinCount;
    } RTL_CRITICAL_SECTION, *PRTL_CRITICAL_SECTION;

    LockCount:
    它被初始化为数值 -1
    此数值等于或大于 0 时,表示此临界区被占用

    等待获得临界区的线程数:LockCount - (RecursionCount -1)

    RecursionCount:
    此字段包含所有者线程已经获得该临界区的次数

    OwningThread:
    此字段包含当前占用此临界区的线程的线程标识符
    此线程 ID 与GetCurrentThreadId 所返回的 ID 相同

    下面是一段伪代码 如果不出错的话应该输出4000

    #include <iostream>
    #include<windows.h>
    using namespace std;
    CRITICAL_SECTION ics;
    
    int icount=0; 
    DWORD WINAPI ThreadA(LPVOID lp)
    {
    
        for(int i=0;i<1000 ;i++ )
        {
    //    EnterCriticalSection(&ics);
        Sleep(1);
        icount++;
    //    LeaveCriticalSection(&ics);
         }
        
    
        
    return 0;
    }
    
    DWORD WINAPI ThreadB(LPVOID lp)
    {
    
        for(int i=0;i<1000 ;i++ )
        {
    //    EnterCriticalSection(&ics);
            Sleep(1);
            icount++;
    //    LeaveCriticalSection(&ics);
        }
        
        
    return 0;
    }
    
    DWORD WINAPI ThreadC(LPVOID lp)
    {
        
        for(int i=0;i<1000 ;i++ )
        {
    //        EnterCriticalSection(&ics);
            Sleep(1);
            icount++;
    //        LeaveCriticalSection(&ics);
        }
      
    return 0;
    }
    
    DWORD WINAPI ThreadD(LPVOID lp)
    {
        
        for(int i=0;i<1000 ;i++ )
        {
    //    EnterCriticalSection(&ics);
             Sleep(1);
            icount++;
    //      LeaveCriticalSection(&ics);
        }
        
        return 0;
    }
    int main(int argc, char *argv[])
    {   InitializeCriticalSection(&ics);
        HANDLE ha=CreateThread(NULL,0,ThreadA,NULL,0,NULL);
        HANDLE hb=CreateThread(NULL,0,ThreadB,NULL,0,NULL);
         HANDLE hC=CreateThread(NULL,0,ThreadC,NULL,0,NULL);
        HANDLE hD=CreateThread(NULL,0,ThreadD,NULL,0,NULL);
       
        ::WaitForSingleObject(ha,INFINITE); 
        ::WaitForSingleObject(hb,INFINITE); 
        ::WaitForSingleObject(hC,INFINITE); 
        ::WaitForSingleObject(hD,INFINITE); 
        printf("%d",icount);
        return 0;
    }
  • 相关阅读:
    Evaluate Reverse Polish Notation
    openstack VM可以ping外部网络,但是外部网络ping不通VM
    Object Storage(Swift)安装过程——Havana
    完数c实现
    ubuntu用户及用户组文件信息
    Ubuntu12.04安装java以及Eclipse和Tomcat
    Ubuntu 12.04 Server OpenStack Havana多节点(OVS+GRE)安装
    ERROR:the server has either erred or is incapable of performing the requested operation
    openMPI小集群安装
    分片传输——send和recv函数
  • 原文地址:https://www.cnblogs.com/xuexidememeda/p/12653096.html
Copyright © 2011-2022 走看看