zoukankan      html  css  js  c++  java
  • 线程同步(windows平台):临界区

    一:介绍

           临界区指的是一个访问共用资源(例:全局变量)的程序片段,该共用资源无法同时被多个线程访问的特性。有多个线程试图同时访问临界区,那么在有一个线程进入后其他所有试图访问此临界区的线程将被挂起,并一直持续到进入临界区的线程离开。临界区在被释放后,其他线程可以继续抢占,并以此达到用原子方式操作共享资源的目的。

      临界区在使用时以CRITICAL_SECTION结构对象保护共享资源,并分别用EnterCriticalSection()和LeaveCriticalSection()函数去标识和释放一个临界区。所用到的CRITICAL_SECTION结构对象必须经过InitializeCriticalSection()的初始化后才能使用,而且必须确保所有线程中的任何试图访问此共享资源的代码都处在此临界区的保护之下。否则临界区将不会起到应有的作用,共享资源依然有被破坏的可能。

    二:步骤

    1. 创建临界区对象:CRITICAL_SECTION critical
    2. 初始化临界区:InitializeCriticalSection(&critical)
    3. 进入临界区:EnterCriticalSection(&critical)
    4. 释放临界区:LeaveCriticalSection(&critical)

    三:代码实现

    /********************************************************
    Copyright (C),  2016-2018,
    FileName:		t12
    Author:        	woniu201
    Email:         	wangpengfei.201@163.com
    Created:       	2018/10/23
    Description:	线程同步-临界区
    ********************************************************/
    #include <iostream>
    #include <Windows.h>
    using namespace std;
    
    volatile int number = 1;
    CRITICAL_SECTION critical;  //临界区句柄
    
    DWORD CALLBACK ThreadFun1(LPVOID pParam)
    {
    	while (1)
    	{
    		EnterCriticalSection(&critical);
    		cout << "Thread1:" << number++ << endl;
    		if (number >= 1000)
    		{
    			break;
    		}
    		LeaveCriticalSection(&critical);
    	}
    	
    	return 0;
    }
    
    DWORD CALLBACK ThreadFun2(LPVOID pParam)
    {
    	while (1)
    	{
    		EnterCriticalSection(&critical);
    		cout << "Thread2:" << number++ << endl;
    		LeaveCriticalSection(&critical);
    		if (number >= 1000)
    		{
    			break;
    		}
    	}
    	return 0;
    }
    
    
    int main()
    {
    	InitializeCriticalSection(&critical);
    	CreateThread(NULL, 0, ThreadFun1, NULL, 0, NULL);
    	CreateThread(NULL, 0, ThreadFun2, NULL, 0, NULL);
    
    	getchar();
    	return 1;
    }

                                                                        欢迎加群交流:C/C++开发交流

  • 相关阅读:
    drf框架 APView的请求生命周期
    web API接口、restful规范
    vue项目安装插件配置
    vue项目、路由
    day67
    vue组件
    day66
    HDFS(Hadoop Distribute File System)
    JVM运行优化学习笔记
    ELK(检索)
  • 原文地址:https://www.cnblogs.com/woniu201/p/11694573.html
Copyright © 2011-2022 走看看