MFC - Listes liées
UNE linked listest une structure de données linéaire où chaque élément est un objet distinct. Chaque élément (nous l'appellerons un nœud) d'une liste comprend deux éléments - les données et une référence au nœud suivant. Le dernier nœud a une référence à null.
Une liste chaînée est une structure de données constituée d'un groupe de nœuds qui représentent ensemble une séquence. C'est un moyen de stocker des données avec des structures afin que le programmeur puisse créer automatiquement un nouvel emplacement pour stocker les données chaque fois que nécessaire. Certaines de ses principales caractéristiques sont -
La liste liée est une séquence de liens contenant des éléments.
Chaque lien contient une connexion à un autre lien.
Chaque élément de la liste est appelé un nœud.
Si la liste contient au moins un nœud, un nouveau nœud est positionné comme dernier élément de la liste.
Si la liste n'a qu'un seul nœud, ce nœud représente le premier et le dernier élément.
Il existe deux types de liste de liens -
Liste liée individuellement
Les listes à liaison unique sont un type de structure de données. Dans une liste liée individuellement, chaque nœud de la liste stocke le contenu du nœud et un pointeur ou une référence vers le nœud suivant de la liste.
Liste doublement liée
Une liste doublement liée est une structure de données liée qui se compose d'un ensemble d'enregistrements liés séquentiellement appelés nœuds. Chaque nœud contient deux champs qui font référence au nœud précédent et au nœud suivant dans la séquence de nœuds.
Classe CList
MFC fournit une classe CListqui est une implémentation de liste liée de modèle et fonctionne parfaitement. Les listes CList se comportent comme des listes à double lien. Une variable de type POSITION est une clé pour la liste. Vous pouvez utiliser une variable POSITION comme itérateur pour parcourir une liste séquentiellement et comme signet pour contenir une place.
N ° Sr. | Nom et description |
---|---|
1 | AddHead Ajoute un élément (ou tous les éléments d'une autre liste) à la tête de la liste (crée une nouvelle tête). |
2 | AddTail Ajoute un élément (ou tous les éléments d'une autre liste) à la fin de la liste (crée une nouvelle queue). |
3 | Find Obtient la position d'un élément spécifié par la valeur du pointeur. |
4 | FindIndex Obtient la position d'un élément spécifié par un index de base zéro. |
5 | GetAt Obtient l'élément à une position donnée. |
6 | GetCount Renvoie le nombre d'éléments de cette liste. |
sept | GetHead Renvoie l'élément head de la liste (ne peut pas être vide). |
8 | GetHeadPosition Renvoie la position de l'élément head de la liste. |
9 | GetNext Obtient l'élément suivant pour l'itération. |
dix | GetPrev Obtient l'élément précédent pour l'itération. |
11 | GetSize Renvoie le nombre d'éléments de cette liste. |
12 | GetTail Renvoie l'élément de queue de la liste (ne peut pas être vide). |
13 | GetTailPosition Renvoie la position de l'élément de queue de la liste. |
14 | InsertAfter Insère un nouvel élément après une position donnée. |
15 | InsertBefore Insère un nouvel élément avant une position donnée. |
16 | IsEmpty Teste la condition de liste vide (aucun élément). |
17 | RemoveAll Supprime tous les éléments de cette liste. |
18 | RemoveAt Supprime un élément de cette liste, spécifié par position. |
19 | RemoveHead Supprime l'élément de la tête de la liste. |
20 | RemoveTail Supprime l'élément de la fin de la liste. |
21 | SetAt Définit l'élément à une position donnée. |
Voici les différentes opérations sur les objets CList -
Créer un objet CList
Pour créer une collection de valeurs ou d'objets CList, vous devez d'abord décider du type de valeurs de la collection. Vous pouvez utiliser l'un des types de données primitifs existants tels que int, CString, double, etc., comme indiqué ci-dessous dans le code suivant.
CList<double, double>m_list;
Ajouter des articles
Pour ajouter un élément, vous pouvez utiliser la fonction CList :: AddTail (). Il ajoute un élément à la fin de la liste. Pour ajouter un élément au début de la liste, vous pouvez utiliser la fonction CList :: AddHead (). Dans le CList OnInitDialog (), l'objet est créé et quatre valeurs sont ajoutées comme indiqué dans le code suivant.
CList<double, double>m_list;
//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);
Récupérer des éléments
Une variable de type POSITION est une clé pour la liste. Vous pouvez utiliser une variable POSITION comme itérateur pour parcourir une liste de manière séquentielle.
Step 1 - Pour récupérer l'élément de la liste, nous pouvons utiliser le code suivant qui récupérera toutes les valeurs.
//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) {
double nData = m_list.GetNext(pos);
CString strVal;
strVal.Format(L"%.2f\n", nData);
m_strText.Append(strVal);
}
Step 2 - Voici la fonction CMFCCListDemoDlg :: OnInitDialog () complète.
BOOL CMFCCListDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
// TODO: Add extra initialization here
CList<double, double>m_list;
//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);
//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) {
double nData = m_list.GetNext(pos);
CString strVal;
strVal.Format(L"%.f\n", nData);
m_strText.Append(strVal);
}
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
Step 3 - Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Ajouter des éléments au milieu
Pour ajouter un élément au milieu de la liste, vous pouvez utiliser les fonctions CList ::. InsertAfter () et CList ::. InsertBefore (). Il faut deux paramètres - Premièrement, la position (où il peut être ajouté) et Deuxièmement, la valeur.
Step 1 - Insérons un nouvel élément comme indiqué dans le code suivant.
BOOL CMFCCListDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
// TODO: Add extra initialization here
CList<double, double>m_list;
//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);
POSITION position = m_list.Find(85.26);
m_list.InsertBefore(position, 200.0);
m_list.InsertAfter(position, 300.0);
//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) {
double nData = m_list.GetNext(pos);
CString strVal;
strVal.Format(L"%.2f\n", nData);
m_strText.Append(strVal);
}
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
Step 2 - Vous pouvez maintenant voir que nous avons d'abord récupéré la position de la valeur 85.26, puis inséré un élément avant et un élément après cette valeur.
Step 3 - Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Mettre à jour la valeur de l'élément
Pour mettre à jour l'élément au milieu du tableau, vous pouvez utiliser la fonction CArray ::. SetAt (). Il faut deux paramètres - Premièrement, la position et Deuxièmement, la valeur.
Mettons à jour les 300,00 à 400 dans la liste comme indiqué dans le code suivant.
BOOL CMFCCListDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
// TODO: Add extra initialization here
CList<double, double>m_list;
//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);
POSITION position = m_list.Find(85.26);
m_list.InsertBefore(position, 200.0);
m_list.InsertAfter(position, 300.0);
position = m_list.Find(300.00);
m_list.SetAt(position, 400.00);
//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) {
double nData = m_list.GetNext(pos);
CString strVal;
strVal.Format(L"%.2f\n", nData);
m_strText.Append(strVal);
}
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante. Vous pouvez maintenant voir que la valeur de 300,00 est mise à jour à 400,00.
Supprimer des éléments
Pour supprimer un élément particulier, vous pouvez utiliser la fonction CList :: RemoveAt (). Pour supprimer tous les éléments de la liste, la fonction CList :: RemoveAll () peut être utilisée.
Supprimons l'élément, qui a 95,78 comme valeur.
BOOL CMFCCListDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
// TODO: Add extra initialization here
CList<double, double>m_list;
//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);
POSITION position = m_list.Find(85.26);
m_list.InsertBefore(position, 200.0);
m_list.InsertAfter(position, 300.0);
position = m_list.Find(300.00);
m_list.SetAt(position, 400.00);
position = m_list.Find(95.78);
m_list.RemoveAt(position);
//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) {
double nData = m_list.GetNext(pos);
CString strVal;
strVal.Format(L"%.2f\n", nData);
m_strText.Append(strVal);
}
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante. Vous pouvez maintenant voir que la valeur de 95,78 ne fait plus partie de la liste.