W obiektowym programowaniu komputerowym tablica klas może odnosić się do jednego z dwóch typów struktur danych. Niektórzy programiści używają tego terminu do opisania standardowego typu danych tablicy składającego się z elementów, które są instancjami obiektów danej klasy. Może to być również enkapsulowany obiekt tablicy klas, znany również jako obiekt opakowujący, używany zamiast tablicy skalarnej, aby udostępnić różne metody do zarządzania tablicą. Chociaż może istnieć bardziej złożona funkcjonalność, klasa tablicy opakowującej tak naprawdę nie różni się od koncepcji obiektów opakowujących dla innych skalarnych typów danych, takich jak liczby całkowite lub znaki. W obu przypadkach struktura może być używana tylko w kontekście obiektowego języka programowania, który obsługuje klasy.
Pierwsza definicja tablicy klas identyfikuje ją jako standardowy typ danych tablicy, który jest zadeklarowany do przechowywania obiektów utworzonych z jednej określonej klasy. Zwykle robi się to, gdy przechowujemy zestaw serii obiektów, zwłaszcza gdy znana jest maksymalna liczba obiektów, więc tablica nie jest zadeklarowana z nadmierną ilością elementów. Mechanizmy polimorficzne w programowaniu obiektowym oznaczają, że użycie tablicy klas może być bardzo dynamiczne, ponieważ może ona zawierać ogólną nadklasę, umożliwiając przechowywanie różnych podklas jako elementów pomimo ich różnych implementacji. Jednak komplikacja podczas korzystania z tablicy klas może wystąpić, gdy liczba elementów jest nieznana i albo rośnie niż zdefiniowany rozmiar tablicy, albo jest bardzo mała, pozostawiając zmarnowaną przestrzeń pamięci przydzieloną przez tablicę. Rozwiązaniem jest użycie obiektów typu kolekcja, takich jak wektory lub arraylists, zamiast tablicy skalarnej, której nie można zmienić.
Drugą definicją tablicy klas jest obiekt, który zawiera tablicę skalarną, ale także udostępnia szereg metod do manipulowania tablicą i jej zmiany. Niektóre języki implementują bardzo wydajne algorytmy sortowania i wyszukiwania w opakowaniu tablicy klas. Kolejną zaletą korzystania z tablicy, która jest zaimplementowana jako klasa, jest to, że klasę można łatwo przekazywać i zmieniać za pomocą różnych funkcji i metod, zwłaszcza jeśli podstawowa klasa tablicy wywodzi się z ogólnej klasy obiektów. Tablica klas jest często podstawą dla innych typów klas opartych na tablicach w bibliotece programistycznej, takich jak arraylist lub tablica mieszająca. Ponadto niektóre języki pozwalają na rozszerzenie klasy tablicy, co oznacza, że użytkownik może przedefiniować niektóre z podstawowych metod za pomocą bardziej wyspecjalizowanych implementacji, zachowując jednocześnie podstawową funkcjonalność klasy.