📄 dcstack.h
字号:
/* * * Copyright (C) 1994-2005, OFFIS * * This software and supporting documentation were developed by * * Kuratorium OFFIS e.V. * Healthcare Information and Communication Systems * Escherweg 2 * D-26121 Oldenburg, Germany * * THIS SOFTWARE IS MADE AVAILABLE, AS IS, AND OFFIS MAKES NO WARRANTY * REGARDING THE SOFTWARE, ITS PERFORMANCE, ITS MERCHANTABILITY OR * FITNESS FOR ANY PARTICULAR USE, FREEDOM FROM ANY COMPUTER DISEASES OR * ITS CONFORMITY TO ANY SPECIFICATION. THE ENTIRE RISK AS TO QUALITY AND * PERFORMANCE OF THE SOFTWARE IS WITH THE USER. * * Module: dcmdata * * Author: Gerd Ehlers * * Purpose: stack class * * Last Update: $Author: meichel $ * Update Date: $Date: 2005/12/08 16:28:42 $ * CVS/RCS Revision: $Revision: 1.12 $ * Status: $State: Exp $ * * CVS/RCS Log at end of file * */#ifndef DCSTACK_H#define DCSTACK_H#include "dcmtk/config/osconfig.h" /* make sure OS specific configuration is included first */#include "dcmtk/dcmdata/dctypes.h"class DcmObject; // forward declaration/** helper class used by DcmStack. Maintains a single stack entry. */class DcmStackNode{public: /** constructor. * @param obj object pointer for this stack entry */ DcmStackNode(DcmObject *obj); /// destructor, non virtual. ~DcmStackNode(); /** return pointer maintained by this entry * @return object pointer */ DcmObject *value() const;private: /// private undefined copy constructor DcmStackNode(const DcmStackNode &); /// private undefined copy assignment operator DcmStackNode &operator=(const DcmStackNode &); /// pointer to next stack entry, NULL if last one DcmStackNode *link; /// pointer to object referenced by this stack entry DcmObject *objNodeValue; /// class DcmStack directly manipulates the pointer chain friend class DcmStack;};/** this class manages a stack of pointers to DcmObject instances. * The objects pointed to are never touched, e.g. deleted. */class DcmStack{public: /// default constructor, creates empty stack DcmStack(); /** copy constructor. Only pointers to objects are copied, * the DcmObject instances are not duplicated. * @param arg stack to copy from */ DcmStack(const DcmStack& arg); /// destructor, not virtual. Do not derive from this class. ~DcmStack(); /** copy assignment operator. Only pointers to objects are copied, * the DcmObject instances are not duplicated. * @param arg object to assign from * @return reference to this object */ DcmStack& operator=(const DcmStack &arg); /** comparison operator, needed for MSVC5. * @param arg stack to compare to * @return true if stacks are equal, false otherwise */ OFBool operator==(const DcmStack& arg) const; /** dummy comparison operator, needed for MSVC5. * @param arg stack to compare to * @return true if the cardinality of this stack is smaller than the * cardinality of arg, or if the cardinality is equal and pointer * comparison, from the top to the bottom of the stack results * in a smaller pointer for this stack. */ OFBool operator<(const DcmStack& arg) const; /** push new pointer do DcmObject instance on stack * @param obj object pointer to push on stack * @return pointer passed as obj */ DcmObject* push( DcmObject *obj ); /** removes uppermost entry from stack and returns it. * @return uppermost stack entry */ DcmObject* pop(); /** returns uppermost entry of stack without removing it. * @returns uppermost stack entry */ DcmObject* top() const; /** returns n-th element from stack without removing it. * @return n-th element from stack */ DcmObject* elem(const unsigned long number) const; /** checks if the stack is empty * @return true if stack is empty, false otherwise */ OFBool empty() const; /** returns cardinality (number of entries) of the stack * @return cardinality of stack */ unsigned long card() const; /** returns the stack to default-constructed state, i.e. empty state. */ void clear();private: /// pointer to the upmost stack entry, NULL if empty DcmStackNode *topNode_; /// current cardinality of the stack unsigned long cardinality_;};#endif // DCSTACK_H/* * CVS/RCS Log: * $Log: dcstack.h,v $ * Revision 1.12 2005/12/08 16:28:42 meichel * Changed include path schema for all DCMTK header files * * Revision 1.11 2004/04/14 11:50:21 joergr * Added const qualifier to parameter to keep Sun CC 2.0.1 quiet. * * Revision 1.10 2003/06/02 16:52:20 meichel * Cleaned up implementation of DcmStack, added doc++ comments * * Revision 1.9 2001/06/01 15:48:44 meichel * Updated copyright header * * Revision 1.8 2000/03/08 16:26:18 meichel * Updated copyright header. * * Revision 1.7 1999/03/31 09:24:47 meichel * Updated copyright header in module dcmdata * * */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -