해시테이블 ( Hashtable )

2025. 9. 28. 10:28·⭐C Sharp/15-5. 딕셔너리 해시테이블

해시테이블 ( Hashtable )

C# 에서는 Key 와 Value 를 사용해서 자료를 저장하는 타입이 두 가지가 있다.

해시테이블과 딕셔너리인데 사용법은 거의 동일하지만 내부적으로 처리하는 기술이 다르다.

해시 함수를 이용해 키 ( Key )에 대응되는 값 ( Value )를 빠르게 저장하고 검색할 수 있는 자료구조이다.

C# 에서는 System.Collections.Hashtable 클래스로 제공된다.

 

 

문법

▼선언

using System.Collections;

Hashtable table = new Hashtable();

 

 

▼추가

table.Add("apple", 100);       // 100 (int → object) 박싱 발생
table["banana"] = 200;         // 200 (int → object) 박싱 발생

 

 

▼조회

int value = (int)table["apple"]; // object → int 언박싱 발생

 

 

▼삭제

table.Remove("banana");

 

▼출력

foreach (DictionaryEntry item in table) // Key, Value는 object 타입
{
    // item.Key, item.Value 접근 시 실제 타입으로 캐스팅 필요
    Console.WriteLine($"{item.Key} : {item.Value}");
}

 

 

 

▼예시 코드

Hashtable scoreTable = new Hashtable();
scoreTable.Add("윤수", 95);
scoreTable.Add("호찬", 88);
scoreTable["장한"] = 76;

Console.WriteLine(scoreTable["윤수"]); // 95 출력

if (scoreTable.ContainsKey("호찬"))
    Console.WriteLine("호찬의 점수 존재");

foreach (DictionaryEntry entry in scoreTable)
    Console.WriteLine($"{entry.Key} : {entry.Value}");

이렇게 보면 Hashtable 은 모든 값이 object 로 저장된다.

int , string 같은 값 형식 ( Value Type ) 은 무조건 박싱 / 언박싱이 발생한다.

그래서 성능과 타입 안정성 때문에 딕셔너리 ( Dictionary<TKey , TValue> ) 사용을 권장한다.

 

 

주의할 점

  • Hashtable 은 제네릭이 아니다 → 박싱 / 언박싱 발생 가능, 성능 저하
  • Dictionary<TKey, TValue> 사용 권장
  • 키는 중복 불가 , 값은 중복 가능
  • 키 검색 시 ContainsKey() 로 존재 여부 확인 필요
  • 순서가 보장되지 않는다 → 입력한 순서와 다르게 출력될 수 있다.

 

 

정리

해시테이블은 키-값 쌍을 저장하고 해시 함수를 이용해 빠르게 검색/삽입/삭제할 수 있는 비제네릭 컬렉션이다.

 

 

 

참고 자료

https://learn.microsoft.com/ko-kr/dotnet/api/system.collections.hashtable?view=net-9.0

 

'⭐C Sharp > 15-5. 딕셔너리 해시테이블' 카테고리의 다른 글

딕셔너리<TKey , TValue> ( Dictionary )  (0) 2025.09.27
'⭐C Sharp/15-5. 딕셔너리 해시테이블' 카테고리의 다른 글
  • 딕셔너리<TKey , TValue> ( Dictionary )
DevHoChan
DevHoChan
맨땅에서 시작하는 코딩 도전
  • DevHoChan
    Debugging Life
    DevHoChan
  • 전체
    오늘
    어제
    • 분류 전체보기 (374)
      • 🕹️Game Life (1)
      • 🖥️Computer Science (5)
      • 📖TIL (141)
        • 🔥Projects (16)
        • 💡DevTips (5)
        • 🤔발생한 문제와 해결 (5)
        • 🔮Unity Graphics (5)
        • 🎤Interview (3)
        • ✅CodingTest (9)
      • 🚀Game Release (4)
      • 🧊Unity Basic (58)
        • 📌용어 사전 (1)
        • 에디터&인터페이스 (3)
        • 디버그 (1)
        • 라이프사이클 (4)
        • 게임오브젝트 (4)
        • 프리팹 (1)
        • 오브젝트풀링 (4)
        • 애트리뷰트 (2)
        • 트랜스폼 (4)
        • 물리&충돌 (1)
        • 프레임&델타타임 (4)
        • 코루틴&이벤트 (7)
        • 수학&보정함수 (3)
        • 디자인패턴 (9)
        • UGUI (3)
        • 벡터 ( Vector ) (3)
        • 씬 ( Scene ) (2)
        • 데이터 관리 (2)
      • ⭐C Sharp (99)
        • 📌용어 사전 (1)
        • 📌문법 사전 (6)
        • 메모리 관리 (3)
        • 00. 문법 (17)
        • 01. 변수 (3)
        • 02. 자료형 (2)
        • 03. 연산자 (6)
        • 04. 조건문 (2)
        • 05. 반복문 (2)
        • 06. 배열 (3)
        • 07. 메서드(함수) (7)
        • 08. 열거형 (3)
        • 09. 구조체 (2)
        • 10. 참조 (2)
        • 11. 객체 지향 (11)
        • 12. 델리게이트 (3)
        • 13. 디자인 패턴 (7)
        • 14. LINQ (1)
        • 📂▼자료구조 (2)
        • 15-1. 제네릭 (3)
        • 15-2. 배열 (4)
        • 15-3. 리스트 (2)
        • 15-4. 스택과 큐 (2)
        • 15-5. 딕셔너리 해시테이블 (2)
        • 15-6. 트리와 그래프 (3)
      • 📊Algorithm (16)
        • BigO (2)
        • 정렬 (4)
        • 셔플 (2)
        • 탐색 (6)
        • 최적화 (1)
      • 📝Game Design (16)
      • 🤖​AI Tools (12)
        • AI 리뷰 분석 (6)
        • Player2 (0)
        • 3D 모델링 (1)
        • 2D 스프라이트 (0)
        • 이미지 (2)
        • 사운드 (1)
        • 동영상 (1)
        • 문서 (1)
      • 🌍Network (6)
      • 🌱Github (11)
        • 기본 개념 (7)
        • 명령어 (1)
        • 도구 활용 (1)
      • ⚙️Visual Studio (5)
        • 🔧설치 및 환경설정 (2)
        • ⌨️HotKey (1)
        • 🚨디버깅 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    algorithm
    디자인패턴
    자료형
    CodingTest
    gamedesign
    메모리관리
    부트캠프
    c#
    문법
    객체지향
    csharp
    unity
    GitHub
    기획
    자료구조
    게임디자인
    유니티
    OOP
    til
    게임기획
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
DevHoChan
해시테이블 ( Hashtable )
상단으로

티스토리툴바