以下是 CObList::GetNext 方法的声明:
CObject* GetNext(POSITION& rPosition) const;
这个方法接受一个 POSITION 引用作为参数,表示当前位置,然后返回当前位置处的元素指针,并将位置移动到下一个元素。你可以通过不断调用 GetNext 方法,遍历整个链表。
下面是一个简单的示例,演示如何使用 CObList::GetNext 方法:
#include <afx.h> // 包含 MFC 头文件
int main()
{
// 创建一个空的 CObList 对象
CObList myList;
// 在链表尾部添加元素
CObject* pObj1 = new CObject;
myList.AddTail(pObj1);
// 在链表尾部添加另一个元素
CObject* pObj2 = new CObject;
myList.AddTail(pObj2);
// 获取链表中第一个元素的位置
POSITION pos = myList.GetHeadPosition();
// 遍历链表中的元素
while (pos != NULL)
{
CObject* pElement = myList.GetNext(pos);
TRACE("Element: %p\n", pElement);
}
// 释放内存,删除链表中的元素
myList.RemoveAll();
return 0;
}
在这个例子中,首先创建了一个空的 CObList 对象 myList,然后使用 AddTail 方法在链表尾部添加了两个 CObject 类的对象指针。接着,使用 GetHeadPosition 方法获取链表中第一个元素的位置,并通过调用 GetNext 方法遍历链表中的元素。
GetNext 方法返回当前位置处的元素指针,并将位置移动到下一个元素。在实际应用中,你可能会使用更具体的类,而不仅仅是 CObject,因为 CObList 可以存储任何从 CObject 派生的类的指针。
转载请注明出处:http://www.zyzy.cn/article/detail/20920/MFC/CObList