Data Structures, Containers, Collections/fr
From Free Pascal wiki
Jump to navigationJump to search
│
English (en) │
français (fr) │
Introduction
La plupart des programmes travaillent sur des données, soit en cherchant, en triant, en itérant ou simplement en insérant ou en récupérant. Par conséquent, des moyens de structurer les données, tels les conteneurs et les collections, sont nécessaires.
Free Pascal est fourni avec de nombreuses structures de données opérant à différents niveaux (RTL, FCL). Il existe par ailleurs des solutions de parties tierces offrant de telles caractéristiques.
Bibliothèque d'exécution (RTL)
- Unité Classes
- TList: : gère une liste de pointeurs ; peut chercher et trier la liste ; possède une caractéristique de notification d'événement.
- TFPList : gère une liste de pointeurs ; peut chercher et trier la liste ; n'a pas de notification d'événement ; plus rapide que TList.
- TStrings : gère une liste de chaînes ; peut chercher, sectionner, sauver vers / charger depuis un fichier, stocker des objets, agir comme un tableau associatif, etc. ; est une classe abstraite.
- TStringList : descendant de TStrings ; implémente les méthodes abstraites de TStrings ; peut chercher, trier, manipuler les doublons ; possède une caractéristique de notification ; c'est un classe concrète.
- TBits : gère une liste de bits (0 or 1) ; utile pour les mappage de bits (pas les pour les formats d'image).
- TCollection et TCollectionItem : forment une gestion de base d'articles nommés.
- FGL (Free Generics Library) unité
Libraire de composants libre (FCL)
FCL-Base
- unité AVL_Tree
- TAVLTree et TAVLTreeNode; voir AVL Tree
- Unité Contnrs
- TFPObjectList
- TObjectList
- TComponentList
- TClassList
- TOrderedList
- TStack
- TObjectStack
- TQueue
- TObjectQueue
- TFPHashList
- TFPHashObjectList
- TFPDataHashTable
- TFPStringHashTable
- TFPObjectHashTable
- TBucketList
- TObjectBucketList
FCL-STL
- GVector unit
- TVector: Implements dynamically self-resizing array, item order is based on insertion order
- GSet unit
- TSet: Implements red-black tree backed set, no order is guaranteed
- GHashSet unit
- THashSet: Implements hashtable backed set, no order is guaranteed
- GStack unit
- TStack: Implements stack, LIFO (last in first out) order
- GQueue unit
- TQueue: Implements stack, items are pushed from front, FIFO (first in first out) order
- GPriorityQueue unit
- TPriorityQueue: Implements heap backed priority queue, order is based on given compare function
- GDeQue unit
- TDeque: Implements double ended queue, items can be pushed and popped from either front or back
- GMap unit
- TMap: Implements TSet (and therefore, red-black tree) backed map
- GHashMap unit
- THashMap: Implements hashtable backed map
- GTree unit
- TTree: Implements k-ary tree, supports depth first and breadth first traversal
Lazarus/LCL
- AvgLvlTree: Versions étendues de FPC/FCL TAVLTree et TAVLTreeNode; voir AVL Tree
3rd party
project | license | generic | types | notes |
---|---|---|---|---|
Containers library for Lazarus | ?? | Non | al,rb,hm,hs,ll,q,s,v | portage de Container, bibliothèque Delphi du domaine public |
heContnrs | BSD3 | Oui | ... | ... |
Fundamentals | BSD | Non | ... | dans Utils/cDataStructs.pas |
RBS AntiDOT | GPLv2 | ?? | ... | ... |
LightContainers | FPC | Non+Oui | ... | Variantes génériques et non-génériques. (Delphi n'optimise pas les génériques). Plutôt de bas-niveau |
DeCAL | MPL | Non | ... | browse variantes + interfaces, relativement lent. |
hovadur DeCAL | MPL | Non | al, as, ll, rb, hm, hs, tm, ts, bs | guide.pdf DeCAL fonctionne dans Lazarus (windows 64 bit/32 bit, linux 64 bit/32 bit) and Delphi7, Delphi XE2. |
StringHashMap | MPL1.0 | ?? | ... | portage de code de la JCL |
GContnrs | LGPLv2 + linking exception | Oui | v, hm, hs, ll, q, dq, s, ts, tm, bs | ... |
CL4fpc | GPLv2 | Oui | ... | ... |
code | data type |
---|---|
al | array list |
as | array set |
rb | red-black tree |
hm | hashmap |
hs | hashset |
ll | linked list |
q | queue |
dq | dequeue |
s | stack |
v | vector |
tm | treemap |
ts | treeset |
bs | bitset |