⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 boundedfifo.h

📁 功能非常强的写日志程序
💻 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 + -