📄 boundedfifo.h
字号:
/* * Copyright 2003,2004 The Apache Software Foundation. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _LOG4CXX_HELPERS_BOUNDED_FIFO_H#define _LOG4CXX_HELPERS_BOUNDED_FIFO_H#include <log4cxx/helpers/objectimpl.h>#include <log4cxx/helpers/objectptr.h>#include <vector>#include <log4cxx/spi/loggingevent.h>namespace log4cxx{ namespace helpers { class BoundedFIFO; typedef ObjectPtrT<BoundedFIFO> BoundedFIFOPtr; /** <code>BoundedFIFO</code> serves as the bounded first-in-first-out buffer heavily used by the AsyncAppender. */ class LOG4CXX_EXPORT BoundedFIFO : public virtual Object, public virtual ObjectImpl { std::vector<spi::LoggingEventPtr> buf; int numElements; int first; int next; int maxSize; public: DECLARE_ABSTRACT_LOG4CXX_OBJECT(BoundedFIFO) BEGIN_LOG4CXX_CAST_MAP() LOG4CXX_CAST_ENTRY(BoundedFIFO) END_LOG4CXX_CAST_MAP() /** Instantiate a new BoundedFIFO with a maximum size passed as argument. */ BoundedFIFO(int maxSize); /** Get the first element in the buffer. Returns <code>null</code> if there are no elements in the buffer. */ spi::LoggingEventPtr get(); /** Place a {@link spi::LoggingEvent LoggingEvent} in the buffer. If the buffer is full then the event is <b>silently dropped</b>. It is the caller's responsability to make sure that the buffer has free space. */ void put(const spi::LoggingEventPtr& o); /** Get the maximum size of the buffer. */ inline int getMaxSize() const { return maxSize; } /** Return <code>true</code> if the buffer is full, i.e. of the number of elements in the buffer equals the buffer size. */ inline bool isFull() const { return numElements == maxSize; } /** Get the number of elements in the buffer. This number is guaranteed to be in the range 0 to <code>maxSize</code> (inclusive). */ inline int length() const { return numElements; } /** Resize the buffer to a new size. If the new size is smaller than the old size events might be lost. */ void resize(int newSize); /** Returns <code>true</code> if there is just one element in the buffer. In other words, if there were no elements before the last #put operation completed. */ inline bool wasEmpty() const { return numElements == 1; } /** Returns <code>true</code> if the number of elements in the buffer plus 1 equals the maximum buffer size, returns <code>false</code> otherwise. */ inline bool wasFull() const { return (numElements+1 == maxSize); } }; // class BoundedFIFO } // namespace helpers}; // namespace log4cxx#endif // _LOG4CXX_HELPERS_BOUNDED_FIFO_H
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -