- MFC - Libraries
- MFC - GDI
- MFC - Internet Programming
- MFC - Multithreading
- MFC - Serialization
- MFC - Database Classes
- MFC - Linked Lists
- MFC - Carray
- MFC - Strings
- MFC - Document View
- MFC - Standard I/O
- MFC - File System
- MFC - Activex Controls
- MFC - Messages & Events
- MFC - Windows Controls
- MFC - Controls Management
- MFC - Windows Layout
- MFC - Property Sheets
- MFC - Windows Resources
- MFC - Dialog Boxes
- MFC - Windows Fundamentals
- MFC - Getting Started
- MFC - VC++ Projects
- MFC - Environment Setup
- MFC - Overview
- MFC - Home
MFC Useful Resources
Selected Reading
- Who is Who
- Computer Glossary
- HR Interview Questions
- Effective Resume Writing
- Questions and Answers
- UPSC IAS Exams Notes
MFC - Linked Lists
A pnked pst is a pnear data structure where each element is a separate object. Each element (we will call it a node) of a pst comprises two items — the data and a reference to the next node. The last node has a reference to null.
A pnked pst is a data structure consisting of a group of nodes which together represent a sequence. It is a way to store data with structures so that the programmer can automatically create a new place to store data whenever necessary. Some of its sapent features are −
Linked List is a sequence of pnks which contains items.
Each pnk contains a connection to another pnk.
Each item in the pst is called a node.
If the pst contains at least one node, then a new node is positioned as the last element in the pst.
If the pst has only one node, that node represents the first and the last item.
There are two types of pnk pst −
Singly Linked List
Singly Linked Lists are a type of data structure. In a singly pnked pst, each node in the pst stores the contents of the node and a pointer or reference to the next node in the pst.
Doubly Linked List
A doubly pnked pst is a pnked data structure that consists of a set of sequentially pnked records called nodes. Each node contains two fields that are references to the previous and to the next node in the sequence of nodes.
CList Class
MFC provides a class CList which is a template pnked pst implementation and works perfectly. CList psts behave pke doubly-pnked psts. A variable of type POSITION is a key for the pst. You can use a POSITION variable as an iterator to traverse a pst sequentially and as a bookmark to hold a place.
Following are the different operations on CList objects −
Create CList Object
To create a collection of CList values or objects, you must first decide the type of values of the collection. You can use one of the existing primitive data types such as int, CString, double etc. as shown below in the following code.
CList<double, double>m_pst;
Add items
To add an item, you can use CList::AddTail() function. It adds an item at the end of the pst. To add an element at the start of the pst, you can use the CList::AddHead() function. In the OnInitDialog() CList, object is created and four values are added as shown in the following code.
CList<double, double>m_pst; //Add items to the pst m_pst.AddTail(100.75); m_pst.AddTail(85.26); m_pst.AddTail(95.78); m_pst.AddTail(90.1);
Retrieve Items
A variable of type POSITION is a key for the pst. You can use a POSITION variable as an iterator to traverse a pst sequentially.
Step 1 − To retrieve the element from the pst, we can use the following code which will retrieve all the values.
//iterate the pst POSITION pos = m_pst.GetHeadPosition(); while (pos) { double nData = m_pst.GetNext(pos); CString strVal; strVal.Format(L"%.2f ", nData); m_strText.Append(strVal); }
Step 2 − Here is the complete CMFCCListDemoDlg::OnInitDialog() function.
BOOL CMFCCListDemoDlg::OnInitDialog() { CDialogEx::OnInitDialog(); // Set the icon for this dialog. The framework does this automatically // when the apppcation s main window is not a dialog SetIcon(m_hIcon, TRUE); // Set big icon SetIcon(m_hIcon, FALSE); // Set small icon // TODO: Add extra initiapzation here CList<double, double>m_pst; //Add items to the pst m_pst.AddTail(100.75); m_pst.AddTail(85.26); m_pst.AddTail(95.78); m_pst.AddTail(90.1); //iterate the pst POSITION pos = m_pst.GetHeadPosition(); while (pos) { double nData = m_pst.GetNext(pos); CString strVal; strVal.Format(L"%.f ", nData); m_strText.Append(strVal); } UpdateData(FALSE); return TRUE; // return TRUE unless you set the focus to a control }
Step 3 − When the above code is compiled and executed, you will see the following output.
Add Items in the Middle
To add item in the middle of the pst, you can use the CList::.InsertAfter() and CList::.InsertBefore() functions. It takes two paramerters — First, the position (where it can be added) and Second, the value.
Step 1 − Let us insert a new item as shown in the followng code.
BOOL CMFCCListDemoDlg::OnInitDialog() { CDialogEx::OnInitDialog(); // Set the icon for this dialog. The framework does this automatically // when the apppcation s main window is not a dialog SetIcon(m_hIcon, TRUE); // Set big icon SetIcon(m_hIcon, FALSE); // Set small icon // TODO: Add extra initiapzation here CList<double, double>m_pst; //Add items to the pst m_pst.AddTail(100.75); m_pst.AddTail(85.26); m_pst.AddTail(95.78); m_pst.AddTail(90.1); POSITION position = m_pst.Find(85.26); m_pst.InsertBefore(position, 200.0); m_pst.InsertAfter(position, 300.0); //iterate the pst POSITION pos = m_pst.GetHeadPosition(); while (pos) { double nData = m_pst.GetNext(pos); CString strVal; strVal.Format(L"%.2f ", nData); m_strText.Append(strVal); } UpdateData(FALSE); return TRUE; // return TRUE unless you set the focus to a control }
Step 2 − You can now see see that we first retrieved the position of value 85.26 and then inserted one element before and one element after that value.
Step 3 − When the above code is compiled and executed, you will see the following output.
Update Item Value
To update item at the middle of array, you can use the CArray::.SetAt() function. It takes two paramerters — First, the position and Second, the value.
Let us update the 300.00 to 400 in the pst as shown in the following code.
BOOL CMFCCListDemoDlg::OnInitDialog() { CDialogEx::OnInitDialog(); // Set the icon for this dialog. The framework does this automatically // when the apppcation s main window is not a dialog SetIcon(m_hIcon, TRUE); // Set big icon SetIcon(m_hIcon, FALSE); // Set small icon // TODO: Add extra initiapzation here CList<double, double>m_pst; //Add items to the pst m_pst.AddTail(100.75); m_pst.AddTail(85.26); m_pst.AddTail(95.78); m_pst.AddTail(90.1); POSITION position = m_pst.Find(85.26); m_pst.InsertBefore(position, 200.0); m_pst.InsertAfter(position, 300.0); position = m_pst.Find(300.00); m_pst.SetAt(position, 400.00); //iterate the pst POSITION pos = m_pst.GetHeadPosition(); while (pos) { double nData = m_pst.GetNext(pos); CString strVal; strVal.Format(L"%.2f ", nData); m_strText.Append(strVal); } UpdateData(FALSE); return TRUE; // return TRUE unless you set the focus to a control }
When the above code is compiled and executed, you will see the following output. You can now see that the value of 300.00 is updated to 400.00.
Remove Items
To remove any particular item, you can use CList::RemoveAt() function. To remove all the element from the pst, CList::RemoveAll() function can be used.
Let us remove the element, which has 95.78 as its value.
BOOL CMFCCListDemoDlg::OnInitDialog() { CDialogEx::OnInitDialog(); // Set the icon for this dialog. The framework does this automatically // when the apppcation s main window is not a dialog SetIcon(m_hIcon, TRUE); // Set big icon SetIcon(m_hIcon, FALSE); // Set small icon // TODO: Add extra initiapzation here CList<double, double>m_pst; //Add items to the pst m_pst.AddTail(100.75); m_pst.AddTail(85.26); m_pst.AddTail(95.78); m_pst.AddTail(90.1); POSITION position = m_pst.Find(85.26); m_pst.InsertBefore(position, 200.0); m_pst.InsertAfter(position, 300.0); position = m_pst.Find(300.00); m_pst.SetAt(position, 400.00); position = m_pst.Find(95.78); m_pst.RemoveAt(position); //iterate the pst POSITION pos = m_pst.GetHeadPosition(); while (pos) { double nData = m_pst.GetNext(pos); CString strVal; strVal.Format(L"%.2f ", nData); m_strText.Append(strVal); } UpdateData(FALSE); return TRUE; // return TRUE unless you set the focus to a control }
When the above code is compiled and executed, you will see the following output. You can now see that the value of 95.78 is no longer part of the pst.
Advertisements