2022-11-10 03:34:52 +08:00
|
|
|
|
/*----------------------------------------------------------------------------------------------------
|
|
|
|
|
|
#
|
|
|
|
|
|
# Copyright (c) 2022 Yuankang Liang(XerolySkinner)
|
|
|
|
|
|
#
|
|
|
|
|
|
# <09><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ԭ<EFBFBD><D4AD><EFBFBD>ṩ,<2C><><EFBFBD>κ<EFBFBD><CEBA><EFBFBD>ʾ<EFBFBD><CABE><EFBFBD><EFBFBD>ʾ
|
|
|
|
|
|
# <09><><EFBFBD>κ<EFBFBD><CEBA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>,<2C><><EFBFBD>߶<EFBFBD><DFB6><EFBFBD><EFBFBD>е<EFBFBD><D0B5>κ<EFBFBD><CEBA><EFBFBD><EFBFBD><EFBFBD><EFBFBD>⳥<EFBFBD><E2B3A5><EFBFBD><EFBFBD>
|
|
|
|
|
|
#
|
|
|
|
|
|
# ʹ<>õ<EFBFBD><C3B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:
|
|
|
|
|
|
# 1. <09><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ,<2C>㲻<EFBFBD><E3B2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>д<EFBFBD><D0B4>ԭʼ<D4AD><CABC><EFBFBD><EFBFBD>.
|
|
|
|
|
|
# 2. <09><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>κ<EFBFBD>Ŀ<EFBFBD><C4BF>,ǰ<><C7B0><EFBFBD>ǰ<EFBFBD>Ȩ<EFBFBD><C8A8><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>и<EFBFBD><D0B8><EFBFBD><EFBFBD><EFBFBD>.
|
|
|
|
|
|
# <09><><EFBFBD>Ұ<EFBFBD>Ȩ<EFBFBD><C8A8><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͬʱ<CDAC><CAB1><EFBFBD><EFBFBD>.
|
|
|
|
|
|
# 3. <09><><EFBFBD><EFBFBD>ʹ<EFBFBD><CAB9>,<2C><><EFBFBD><EFBFBD>,<2C><EFBFBD>,<2C>ַ<EFBFBD>,<2C><><EFBFBD><EFBFBD><EFBFBD>۱<EFBFBD><DBB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
|
|
|
|
|
# 4. <09><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڲ<EFBFBD>Ʒ<EFBFBD><C6B7>ʹ<EFBFBD><CAB9>,<2C><>Ʒ<EFBFBD>ĵ<EFBFBD><C4B5>е<EFBFBD><D0B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>͵ĵ<CDB5><C4B5><EFBFBD><EFBFBD>DZ<EFBFBD><C7B1><EFBFBD><EFBFBD><EFBFBD>.
|
|
|
|
|
|
# 5. <09><>֪ͨ<CDA8><D6AA><EFBFBD>ô<EFBFBD><C3B4>κ<EFBFBD><CEBA><EFBFBD>Դɾ<D4B4><C9BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
|
|
|
|
|
#
|
|
|
|
|
|
# Yuankang Liang(XerolySkinner)
|
|
|
|
|
|
# E-mail:zabbcccbbaz@163.com
|
|
|
|
|
|
# QQ:2715099320
|
|
|
|
|
|
# Mobile Phone:13005636215
|
|
|
|
|
|
#
|
|
|
|
|
|
# All rights reserved.
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @file STL_Queue.h
|
|
|
|
|
|
* @brief ʵ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>STL<EFBFBD><EFBFBD><EFBFBD>е<EFBFBD>Queue
|
|
|
|
|
|
* @mainpage <EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD>Ϣ
|
|
|
|
|
|
* @author Yuankang Liang(XerolySkinner)
|
|
|
|
|
|
* @email zabbcccbbaz@163.com
|
|
|
|
|
|
* @version V1.0.0
|
|
|
|
|
|
* @date 2022-11-09 01:03
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
#include "varint.h"
|
|
|
|
|
|
#include <stdlib.h>
|
2022-11-11 03:31:59 +08:00
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
//----------------------------------------------------------------------------------------------------
|
|
|
|
|
|
// <09><><EFBFBD><EFBFBD>ֵö<D6B5><C3B6>
|
|
|
|
|
|
//
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief <EFBFBD><EFBFBD><EFBFBD>еķ<EFBFBD><EFBFBD><EFBFBD>ֵ
|
|
|
|
|
|
*/
|
2022-11-10 03:34:52 +08:00
|
|
|
|
enum QUEUES_RES {
|
|
|
|
|
|
QUEUES_OK, ///< <20>ɹ<EFBFBD>
|
|
|
|
|
|
QUEUES_EMPTY, ///< <20><><EFBFBD><EFBFBD><EFBFBD>ǿյ<C7BF>
|
|
|
|
|
|
QUEUES_REAL_ERROR, ///< <20>ط<EFBFBD><D8B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>realloc
|
|
|
|
|
|
QUEUES_MALL_ERROR ///< <20>ط<EFBFBD><D8B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>malloc
|
|
|
|
|
|
};
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
//----------------------------------------------------------------------------------------------------
|
|
|
|
|
|
// <09><>Ŀ
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief һ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>е<EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
*/
|
|
|
|
|
|
class STL_rQueue{
|
|
|
|
|
|
public:
|
|
|
|
|
|
STL_rQueue(void);
|
|
|
|
|
|
~STL_rQueue(void);
|
|
|
|
|
|
public:
|
|
|
|
|
|
u8 push(u8 var);
|
|
|
|
|
|
u8 pop(void);
|
|
|
|
|
|
u8 top(u8& var);
|
|
|
|
|
|
u32 The_size(void);
|
|
|
|
|
|
u32 The_room(void);
|
|
|
|
|
|
u8 clean(void);
|
|
|
|
|
|
|
|
|
|
|
|
u8 poptop(void);
|
|
|
|
|
|
|
|
|
|
|
|
u8 push32(u32 var);
|
|
|
|
|
|
u32 poptop32(void);
|
|
|
|
|
|
|
|
|
|
|
|
void pushfun(void(*fun)(void));
|
|
|
|
|
|
void (*poptopfun(void))(void);
|
|
|
|
|
|
private:
|
|
|
|
|
|
u32 room; // <09><><EFBFBD><EFBFBD><EFBFBD>ռ<EFBFBD>
|
|
|
|
|
|
u32 size; // <09><><EFBFBD>г<EFBFBD>Ա
|
|
|
|
|
|
u8* dat; // <09><><EFBFBD><EFBFBD>ͷ
|
|
|
|
|
|
};
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////////////////
|
2022-11-11 03:31:59 +08:00
|
|
|
|
//----------------------------------------------------------------------------------------------------
|
|
|
|
|
|
// <09><>Ŀ
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ<EFBFBD><EFBFBD><EFBFBD>еĽڵ<EFBFBD>
|
|
|
|
|
|
*/
|
|
|
|
|
|
struct _lQueue {
|
|
|
|
|
|
struct _lQueue* back; ///< <20><>һ<EFBFBD><D2BB><EFBFBD>ڵ<EFBFBD><DAB5><EFBFBD>ָ<EFBFBD><D6B8>
|
|
|
|
|
|
void* dat; ///< <20><><EFBFBD>ݵ<EFBFBD>ָ<EFBFBD><D6B8>
|
|
|
|
|
|
u32 size; ///< <20><><EFBFBD><EFBFBD><EFBFBD>ݵĴ<DDB5>С
|
|
|
|
|
|
};
|
|
|
|
|
|
typedef struct _lQueues _lQueues;
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief һ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>е<EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
* @note ʹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD>䷽ʽ<EFBFBD><EFBFBD>֯
|
|
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD>е<EFBFBD><EFBFBD>ڴ<EFBFBD><EFBFBD>ռ<EFBFBD><EFBFBD>Ƿ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>,<EFBFBD>ʺϿ<EFBFBD><EFBFBD>ٽ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
*/
|
|
|
|
|
|
class STL_lQueue {
|
|
|
|
|
|
public:
|
|
|
|
|
|
STL_lQueue(void);
|
|
|
|
|
|
~STL_lQueue(void);
|
|
|
|
|
|
public:
|
|
|
|
|
|
u8 push(void*& var, u32 size);
|
|
|
|
|
|
u8 pop(void);
|
|
|
|
|
|
u8 top(void*& var, u32& size);
|
|
|
|
|
|
|
|
|
|
|
|
u8 push8(u8 var);
|
|
|
|
|
|
u8 top8(u8& var);
|
|
|
|
|
|
u8 poptop8(void);
|
|
|
|
|
|
|
|
|
|
|
|
u8 push32(u32 var);
|
|
|
|
|
|
u8 top32(u32& var);
|
|
|
|
|
|
u32 poptop32(void);
|
|
|
|
|
|
|
|
|
|
|
|
u8 pushfun(void(*fun)(void));
|
|
|
|
|
|
void (*poptopfun(void))(void);
|
|
|
|
|
|
private:
|
|
|
|
|
|
u32 mem; // <09><><EFBFBD>г<EFBFBD>Ա
|
|
|
|
|
|
_lQueue* Hdat; // <09><><EFBFBD>н<EFBFBD><D0BD><EFBFBD>
|
|
|
|
|
|
_lQueue* Tdat; // <09><><EFBFBD>е<EFBFBD><D0B5><EFBFBD>
|
|
|
|
|
|
};
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////////////////
|
2022-11-10 03:34:52 +08:00
|
|
|
|
#endif
|