queue.cpp

来自「真正的传奇源代码」· C++ 代码 · 共 87 行

CPP
87
字号
// **************************************************************************************
//
//  Euyheon's Queue Class
//
//  All written by Euy-heon, Jeong.
//  Copyright(C) 1999-2001 Euy-heon, Jeong. All rights reserved.
//
//	Win32 Version : Compiled by Microsoft Visual C++ 6.0
//
//	Problems & History
//	------------------
//
// **************************************************************************************

#include "stdafx.h"

CWHQueue::CWHQueue()
{
//	InitializeCriticalSection(&m_cs);

	m_btQPushPos	= 0;
	m_btQPopPos		= 0; 

	m_btCount		= 0;
}

CWHQueue::~CWHQueue()
{
//	DeleteCriticalSection(&m_cs);
}

BOOL CWHQueue::PushQ(BYTE *lpbtQ)
{
	BOOL fRet = TRUE;

//	EnterCriticalSection(&m_cs);

	__try
	{
		if (m_btQPushPos + 1 == m_btQPopPos || (m_btQPushPos + 1 == (unsigned) QUEUE_MAX && !m_btQPopPos))
		{
			fRet = FALSE;
			__leave;			// Queue is full.
		}

		m_lpCircularQ[m_btQPushPos] = lpbtQ;
		m_btQPushPos++;
		m_btCount++;

		if (m_btQPushPos == (unsigned) QUEUE_MAX)
			m_btQPushPos = 0;
	}
	__finally
	{
//		LeaveCriticalSection(&m_cs);
	}
	
	return fRet;
}

BYTE *CWHQueue::PopQ()
{
	BYTE *pbt = NULL;

//	EnterCriticalSection(&m_cs);

	__try
	{
		if (m_btQPopPos == (unsigned) QUEUE_MAX)
			m_btQPopPos = 0;

		if (m_btQPopPos == m_btQPushPos)
			__leave;			// No event.

		m_btQPopPos++;
		m_btCount--;

		pbt = m_lpCircularQ[m_btQPopPos - 1];
	}
	__finally
	{
//		LeaveCriticalSection(&m_cs);
	}

	return pbt;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?