CSimpleList的实现与测试

本文介绍了一个简单的自定义列表类CSimpleList的实现方法,该类主要用于管理内存中一系列元素的链表结构。文章展示了如何添加元素到链表头部、如何移除指定元素,并提供了完整的示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简单列表类的实现

_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);

	//为实现接口所需的成员
	void	*m_pHead;
	size_t	m_nextOffset;
	void**	GetNextPtr(void* preElement) const;
};

//类的内联函数
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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值