C++中CSimpleList的實現(xiàn)與測試實例
更新時間:2014年10月11日 08:58:10 投稿:shichen2014
這篇文章主要介紹了C++中CSimpleList的實現(xiàn)與測試實例,較為詳細的講述了C++列表類的實現(xiàn)方法,需要的朋友可以參考下
本文實例講述了C++簡單列表類的實現(xiàn)方法。分享給大家供大家參考。具體方法如下:
_AFXTLS.CPP文件如下:
//#include "StdAfx.h
#include <stddef.h>
#include <stdio.h>
#include "_AFXTLS_.H"
struct MyThreadData{
MyThreadData* pNext;
int nShortData;
};
void CSimpleList::AddHead(void *p)
{
*GetNextPtr(p)=m_pHead;
m_pHead = p;
}
BOOL CSimpleList::Remove(void* p)
{
BOOL bRet = FALSE;
if (p == NULL)
{
bRet = FALSE;
}
if (p == m_pHead)
{
m_pHead = GetNext(m_pHead);
bRet = TRUE;
}
else
{
void* pTest;
pTest = m_pHead;
while (pTest && (GetNext(pTest) != p))
{
pTest = GetNext(pTest);
}
if (pTest != NULL)
{
*GetNextPtr(pTest) = GetNext(p);
bRet = TRUE;
}
}
return bRet;
}
void main()
{
MyThreadData* pData;
CSimpleList list;
list.Construct(offsetof(MyThreadData, pNext));
for (int i=0;i<10;i++)
{
pData = new MyThreadData;
pData->nShortData = i;
list.AddHead(pData);
}
//遍歷鏈表,釋放MyThreadData對象占用的空間
pData = (MyThreadData*)list.GetHead();
while(pData != NULL)
{
MyThreadData* pNextData = pData->pNext;
printf("The value is %d\n",pData->nShortData);
delete pData;
pData = pNextData;
}
}
_AFXTLS_.H文件如下:
//#include "StdAfx.h
#ifndef __AFXTLS_H__
#define __AFXTLS_H__
#include <Windows.h>
class CSimpleList
{
public:
CSimpleList(int nNextOffset=0);
void Construct(int nNextOffset);
//接口
BOOL IsEmpty() const;
void AddHead(void *p);
void RemoveAll();
void* GetHead() const;
void* GetNext(void* preElement) const;
BOOL Remove(void* p);
//為實現(xiàn)接口所需的成員
void *m_pHead;
size_t m_nextOffset;
void** GetNextPtr(void* preElement) const;
};
//類的內(nèi)聯(lián)函數(shù)
inline CSimpleList::CSimpleList(int nNextOffset)
{m_pHead = NULL; m_nextOffset = nNextOffset; }
inline void CSimpleList::Construct(int nNextOffset)
{m_nextOffset = nNextOffset; }
inline BOOL CSimpleList::IsEmpty() const
{
return m_pHead==NULL;
}
//inline void AddHead(void *p)
//{
//
//}
inline void CSimpleList::RemoveAll()
{
m_pHead = NULL;
}
inline void* CSimpleList::GetHead() const
{
return m_pHead;
}
inline void* CSimpleList::GetNext(void* preElement) const
{
return *GetNextPtr(preElement);
}
//inline BOOL CSimpleList::Remove(void* p)
//{
//
//}
inline void** CSimpleList::GetNextPtr(void* preElement) const
{
return (void**)((BYTE*)preElement+m_nextOffset);
}
#endif
希望本文所述對大家的C++程序設(shè)計有所幫助。
相關(guān)文章
C語言實現(xiàn)進程5狀態(tài)模型的狀態(tài)機
狀態(tài)機在實際工作開發(fā)中應(yīng)用非常廣泛,用這幅圖就可以很清晰的表達整個狀態(tài)的流轉(zhuǎn)。本篇通過C語言實現(xiàn)一個簡單的進程5狀態(tài)模型的狀態(tài)機,讓大家熟悉一下狀態(tài)機的魅力,需要的可以參考一下2022-10-10
c語言中十進制轉(zhuǎn)二進制顯示小工具的實現(xiàn)代碼
本篇文章是對c語言中十進制轉(zhuǎn)二進制顯示小工具的實現(xiàn)代碼進行了詳細的分析的介紹,需要的朋友參考下2013-05-05
Clion配置opencv開發(fā)環(huán)境的詳細過程
這篇文章主要介紹了Clion配置opencv開發(fā)環(huán)境的詳細過程,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考的下2022-04-04
C語言實例真題講解數(shù)據(jù)結(jié)構(gòu)中單向環(huán)形鏈表
鏈表可以說是一種最為基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu)了,而單向鏈表更是基礎(chǔ)中的基礎(chǔ)。鏈表是由一組元素以特定的順序組合或鏈接在一起的,不同元素之間在邏輯上相鄰,但是在物理上并不一定相鄰。在維護一組數(shù)據(jù)集合時,就可以使用鏈表,這一點和數(shù)組很相似2022-04-04

