feat add circle_queue
This commit is contained in:
@@ -32,10 +32,10 @@ void Log(LogLevel level,
|
||||
// sled::Log(level, tag, fmt, __FILE__, __FUNCTION__, __VA_ARGS__)
|
||||
|
||||
#define _SLOG(level, tag, fmt_str, ...) \
|
||||
sled::Log(level, tag, fmt::format(fmt_str, #__VA_ARGS__).c_str(), \
|
||||
sled::Log(level, tag, fmt::format(fmt_str, ##__VA_ARGS__).c_str(), \
|
||||
__FILE__, __LINE__, __FUNCTION__)
|
||||
|
||||
#define SLOG(level, tag, fmt, ...) _SLOG(level, tag, fmt, #__VA_ARGS__)
|
||||
#define SLOG(level, tag, fmt, ...) _SLOG(level, tag, fmt, ##__VA_ARGS__)
|
||||
#define SLOG_TRACE(tag, fmt, ...) \
|
||||
SLOG(sled::LogLevel::kTrace, tag, fmt, __VA_ARGS__)
|
||||
#define SLOG_INFO(tag, fmt, ...) \
|
||||
@@ -75,12 +75,18 @@ void Log(LogLevel level,
|
||||
#define LOGF_IF(cond, tag, fmt, ...) \
|
||||
SLOG_IF(cond, sled::LogLevel::kFatal, tag, fmt, __VA_ARGS__)
|
||||
|
||||
#define LOGV(tag, fmt, ...) SLOG(sled::LogLevel::kTrace, tag, fmt, #__VA_ARGS__)
|
||||
#define LOGD(tag, fmt, ...) SLOG(sled::LogLevel::kDebug, tag, fmt, #__VA_ARGS__)
|
||||
#define LOGI(tag, fmt, ...) SLOG(sled::LogLevel::kInfo, tag, fmt, #__VA_ARGS__)
|
||||
#define LOGV(tag, fmt, ...) \
|
||||
SLOG(sled::LogLevel::kTrace, tag, fmt, ##__VA_ARGS__)
|
||||
#define LOGD(tag, fmt, ...) \
|
||||
SLOG(sled::LogLevel::kDebug, tag, fmt, ##__VA_ARGS__)
|
||||
#define LOGI(tag, fmt, ...) SLOG(sled::LogLevel::kInfo, tag, fmt, ##__VA_ARGS__)
|
||||
#define LOGW(tag, fmt, ...) \
|
||||
SLOG(sled::LogLevel::kWarning, tag, fmt, #__VA_ARGS__)
|
||||
#define LOGE(tag, fmt, ...) SLOG(sled::LogLevel::kError, tag, fmt, #__VA_ARGS__)
|
||||
#define LOGF(tag, fmt, ...) SLOG(sled::LogLevel::kFatal, tag, fmt, #__VA_ARGS__)
|
||||
SLOG(sled::LogLevel::kWarning, tag, fmt, ##__VA_ARGS__)
|
||||
#define LOGE(tag, fmt, ...) \
|
||||
SLOG(sled::LogLevel::kError, tag, fmt, ##__VA_ARGS__)
|
||||
#define LOGF(tag, fmt, ...) \
|
||||
SLOG(sled::LogLevel::kFatal, tag, fmt, ##__VA_ARGS__)
|
||||
|
||||
#define ASSERT(cond, fmt, ...) SLOG_ASSERT(cond, "ASSERT", fmt, ##__VA_ARGS__);
|
||||
|
||||
#endif// LOG_H
|
||||
|
@@ -53,9 +53,9 @@ public:
|
||||
|
||||
private:
|
||||
static const int kForeverMs = -1;
|
||||
static int ToCmsWait(TimeDelta max_wait_duration);
|
||||
static int ToCusWait(TimeDelta max_wait_duration);
|
||||
|
||||
bool WaitSelect(int cmsWait, bool process_io);
|
||||
bool WaitSelect(int64_t cusWait, bool process_io);
|
||||
|
||||
uint64_t next_dispatcher_key_ = 0;
|
||||
std::unordered_map<uint64_t, Dispatcher *> dispatcher_by_key_;
|
||||
|
63
include/sled/queue/circle_queue.h
Normal file
63
include/sled/queue/circle_queue.h
Normal file
@@ -0,0 +1,63 @@
|
||||
/**
|
||||
* @file : circle_queue
|
||||
* @created : 星期六 2 24, 2024 16:06:23 CST
|
||||
* @license : MIT
|
||||
**/
|
||||
|
||||
#ifndef CIRCLE_QUEUE_H
|
||||
#define CIRCLE_QUEUE_H
|
||||
|
||||
#include "sled/log/log.h"
|
||||
#include <array>
|
||||
|
||||
namespace sled {
|
||||
|
||||
template<typename T, size_t LEN>
|
||||
class CircleQueue {
|
||||
static_assert(LEN > 0, "LEN should be greater than 0");
|
||||
|
||||
public:
|
||||
void Push(T &&val)
|
||||
{
|
||||
ASSERT(size() < LEN, "queue is full");
|
||||
queue_.get(tail_) = std::move(val);
|
||||
++tail_;
|
||||
}
|
||||
|
||||
void Push(const T &val)
|
||||
{
|
||||
ASSERT(size() < LEN, "queue is full");
|
||||
queue_.get(tail_) = val;
|
||||
++tail_;
|
||||
}
|
||||
|
||||
T &Front()
|
||||
{
|
||||
ASSERT(!empty());
|
||||
return queue_.get(head_);
|
||||
}
|
||||
|
||||
void Pop()
|
||||
{
|
||||
ASSERT(!empty());
|
||||
head_ = (head_ + 1) % (LEN + 1);
|
||||
}
|
||||
|
||||
size_t size() const
|
||||
{
|
||||
return tail_ >= head_ ? tail_ - head_ : (LEN + 1) - (head_ - tail_);
|
||||
}
|
||||
|
||||
bool empty() const { return (tail_ + 1) % (LEN + 1) == head_; }
|
||||
|
||||
bool capacity() const { return LEN; }
|
||||
|
||||
private:
|
||||
std::array<T, LEN + 1> queue_;
|
||||
size_t head_ = 0;
|
||||
size_t tail_ = 0;
|
||||
};
|
||||
|
||||
}// namespace sled
|
||||
|
||||
#endif// CIRCLE_QUEUE_H
|
Reference in New Issue
Block a user