3

我正在为一个项目编写一组链表函数。
我需要为列表节点(int/char)中的数据类型提供灵活性

所以我正在尝试做这样的事情:

在 main.cpp

#define INT_DATA
#include "lists.h"
....

在 list.h 中

#ifdef CHAR_DATA
typedef char DATA_TYPE;
#endif
#ifdef INT_DATA
typedef int DATA_TYPE;
#endif

typedef struct lnode {
    DATA_TYPE data;
    struct lnode* next; //points to the next node
} LNODE;

LNODE * createNewListNode(DATA_TYPE data, LNODE* next);
....

但所有这些似乎都不起作用......当原型不同时,我不想编写重复的代码......

我究竟做错了什么?这可能吗?

请注意

这是一个练习,我不能使用类,我不能使用任何标准库

4

2 回答 2

9

这是 C++ 的模板进入的地方。模板允许您创建实现的框架。在这种情况下,您可能需要一个将“数据类型”作为参数的类。听起来不错……这就是它的样子:

template < typename DATA_TYPE >  
struct lnode {
  DATA_TYPE data;
  lnode<DATA_TYPE>* next; //points to the next node
};

然后你可以像这样创建它们:

lnode<char> charNode;
lnode<int> intNode;
于 2012-04-14T21:20:32.747 回答
2

不要使用定义。使用模板(好文章:)。

此外,这typedef struct lnode { /* ... */ } LNODE;只是 C,甚至不接近 C++。

于 2012-04-14T21:21:25.063 回答