当前位置: 首页 > 图文教程 > 开发语言 > VC++ > 一个简单的链表模版类的实现

VC++
自绘菜单的实现
电子式时钟
VC++工程中加入 SplashScreen 原理释解
类似 MSN 带转义字符的信息发送框的制作(下)
类似 MSN 信息发送框的制作(上)
多功能标签CLabelEx
一步步制作真彩工具条
增加状态栏按钮及其它......
子类化:增强Edit控件为日期输入控件
.NET中的自绘机制
电子八段管的仿真控件
树控件的应用 -- 求子树节点的集
树视控件在多文档中的使用
在List Control中实现列表项目的上下移动
可设置单元格颜色的ClistCtrl类
属性列表的开发
在MDI程序中实现类似WPS2000的文件切换标签
VC控件 TreeCtrl 与 ListCtrl 演示
为对话框中的控件增加提示的简单方法
类似EXCEL的开发库(更新)

VC++ 中的 一个简单的链表模版类的实现


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 67 ::
收藏到网摘: n/a

一个简单的链表模版类的实现


作者:Smoke


源代码下载

    这是翻阅《数据结构、算法与应用——C++语言描述》 以及在网上得到的一些资料后写出来的。起因是在项目中要用到一个链表,但我做一个简单的链表在C++中用的时候跟C差别很多,比如赋值运算(编译器说要做操作符重载,或者考贝构造函数,C++中把结构当成一个类来看了,详见相关介绍的文档或书籍)。后来一想干脆做个template顺便学习一下,一举两得。
几个问题:
CListData和CNode的函数均为内联函数(inline),因为目前的编译器仍不支持分离编译。按《Thinking in C++》一书第16章中的解释是,模版类在定义的时候并没有对内存进行分配置,而是到实例化的情况下才分配内存,因此可以把声明和定义都写在头文件(详见原文)。
因此,如果将两个文件分离则在连接时报错LNK2001。(这问题把我搞得痛苦了好一阵)
在网上及书上的例程中通常是以一个int做为例子,这使得在我们应用的时候很不方便,特别是在不完全理解template的时候。在这里我以一个类(CNodeInfo)作一个节点类型的例子。
代码:

class CNodeInfo{private:	int	m_Count;//Counter or call it PKEY:)	CString	m_strFileName;//for Store filename	DWORD	m_dwFileLen;//for store file length	BOOL	m_bStatus;//Transfers status tag;public: CNodeInfo();	~CNodeInfo();	void SetStatus(BOOL bStatus = FALSE);	BOOL GetStatus();	void SetFileLen(DWORD len);	DWORD GetFileLen();	void SetFileName(CString str);	CString GetFileName();};//private 为数大家可以理解成结构中的元素如:typedef struct _FILESTRUCT_{	int count;	CString strFileName;	DWORD dwFIleLen	BOOL	bStatus;}FILESTRUCTURE.

(如果你想把它改得更通用可以把CString换成char 或者string,其他地方再作相应修改,把BOOL 改成 bool或者用typedef一下)。
Public:是成员函数就不细描述了。比较简单了。代码中注释比较详细,我在这就不写得很细了,把一些我自己认为不容易弄明白的地方写一下就是了(希望有人能读懂我的中式英文,嘿嘿)

参考资料:
《数据结构、算法与应用——C++语言描述》《Thinking in C++》以及网络上相关资料。