STL 질문 드립니다.[Hash_Map]
아시는 분 답변 부탁드립니다.
아래 코드 대로 클래스 파일을 만들어 놓고
CHash_Localnet ht_Localnet;을 선언하였습니다. 글로벌로요...
그리고 데이터를 집어넣고 검색을 하면 잘됩니다. 한데,,,,
A()라는 함수에서 이과정을 전부 하게되면 잘되는데 A()함수에서 put데이터를 하고
B()함수에서 검색을 수행하게 되면 이상하게도 안됩니다. 사이즈를 찍어보면 분명히
제가 집어넣은 갯수대로 나오는데 뭐가 문제일까요 답변 부탁드립니다.
C에서 해쉬테이블을 동적으로 쓸수가없어서 쓰는건데,,, 거참... 난감하네요 ㅠㅠ
#include
#include
#include "global.h"
using namespace std;
typedef struct {
char data[1024];
} localnet;
template
class CHash_Localnet {
public:
typedef __gnu_cxx::hash_map Localnet_Table;
private:
Localnet_Table m_htTable;
public:
void put(char *key, localnet *value) {
m_htTable.insert(std::make_pair(key, value));
}
localnet *get(char *key) {
localnet *value;
Localnet_Table::iterator iter = m_htTable.find(key);
if(iter != m_htTable.end()) {
return value = iter->second;
}
return NULL;
}
bool constainKey(char *key) {
Localnet_Table::iterator iter = m_htTable.find(key);
if(iter != m_htTable.end()) {
return true;
}
return false;
}
int size(void) {
return m_htTable.size();
}
void remove(char *key) {
Localnet_Table::iterator iter;
iter=m_htTable.find(key);
if(iter != m_htTable.end()) {
delete iter->second;
iter->second = NULL;
m_htTable.erase(iter);
}
}
void removeAll(void) {
Localnet_Table::iterator iter;
for(iter=m_htTable.begin(); iter!=m_htTable.end(); ++iter) {
delete iter->second;
iter->second = NULL;
}
m_htTable.clear();
}
void clear(void) {
m_htTable.clear();
}
};
댓글 달기