📄 stlmap.h
字号:
// STLMap.h: interface for the CSTLMap class.
//
//////////////////////////////////////////////////////////////////////
#if !defined(AFX_STLMap_H__9153F571_6888_4BD4_ABC9_E97416B54096__INCLUDED_)
#define AFX_STLMap_H__9153F571_6888_4BD4_ABC9_E97416B54096__INCLUDED_
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
#pragma warning(disable : 4786)
#include <map>
using namespace std;
template <class T> class CSTLMap
{
public:
typedef map < int, T* >::iterator Iterator;
typedef map < int, T* >::value_type ValueType;
map < int, T* > m_UserTypeMap;
int GetSize() { return m_UserTypeMap.size(); };
bool PutData( int key_value, T* pData)
{
if( !pData ) return false;
pair<Iterator, bool> temp_pair = m_UserTypeMap.insert( ValueType( key_value, pData ) );
return temp_pair.second;
};
T* GetData( int key_value )
{
T* pData = NULL;
Iterator iter = m_UserTypeMap.find( key_value );
if( iter == m_UserTypeMap.end() )
return NULL;
else
pData = (*iter).second;
return pData;
};
bool DeleteData( int key_value )
{
if( m_UserTypeMap.empty() )
return false;
Iterator iter = m_UserTypeMap.find( key_value );
if( iter == m_UserTypeMap.end() )
return false;
else {
T* pData = NULL;
pData = (*iter).second;
m_UserTypeMap.erase(iter);
delete pData;
pData = NULL;
return true;
}
};
void DeleteAllData()
{
Iterator iter1 = m_UserTypeMap.begin(), iter2 = m_UserTypeMap.end();
for(; iter1 != iter2; iter1++ )
delete (*iter1).second;
m_UserTypeMap.clear();
};
bool IsExist( int key_value )
{
Iterator iter = m_UserTypeMap.find( key_value );
if( iter == m_UserTypeMap.end() )
return false;
else
return true;
};
bool IsEmpty() { return m_UserTypeMap.empty(); };
CSTLMap() {};
virtual ~CSTLMap() {
DeleteAllData();
};
};
#endif // !defined(AFX_STLMap_H__9153F571_6888_4BD4_ABC9_E97416B54096__INCLUDED_)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -