第一次使用模板,出现了问题,请指点一下

mayulin110 2008-11-11 11:34:55
头文件定义部分:
#include <iostream>
using namespace std;

template <class type> class SingleLink;

template <class T>
class Node
{
public:
friend class SingleLink<T>;
T data;
class Node *Next;
};

template <class type>
class SingleLink
{
public:
SingleLink();
virtual ~SingleLink();

bool insert(type Element);//在当前位置插入值
private:
Node<type> *pHead,*pCurNode,*ptemp;
};
.cpp部分
#include "stdafx.h"
#include "SingleLink.h"

template <class type>
SingleLink<type>::SingleLink()
{//creat a head node
pHead = pCurNode = ptemp = new Node<Type>;
pHead->Next = NULL;
}

template <class type>
SingleLink<type>::~SingleLink()
{
pCurNode = pHead;
while(pCurNode)
{
pHead = pHead->Next;
delete pCurNode;
pCurNode = pHead;
}
}

template <class type>
bool SingleLink<type>::insert(type element)
{//insert the element into current position
if(!pCurNode)
return false;//no link because no head node
else// insert the element into current position
{
ptemp = pCurNode->Next;

pCurNode = pCurNode->Next = new Node<type>;
pCurNode->data = element->data;
pCurNode->Next = ptemp;
}
return true;
}

主程序部分
#include "stdafx.h"
//#include "SingleLink.h"
#include "SingleLink.cpp"

int main(int argc, char* argv[])
{
int a[5] = {1,2,3,4,5};
SingleLink<int> linklist;

for(int i = 0; i < 5; i++)
{
linklist.insert(a[i]);
}
return 0;
}
报的错误:
Compiling...
SLink.cpp
e:\workspace\slink\singlelink.cpp(17) : error C2143: syntax error : missing ';' before '<'
e:\workspace\slink\singlelink.cpp(17) : error C2501: 'SingleLink' : missing storage-class or type specifiers
e:\workspace\slink\singlelink.cpp(17) : error C2059: syntax error : ';'
e:\workspace\slink\singlelink.cpp(17) : error C2143: syntax error : missing ';' before '<'
e:\workspace\slink\singlelink.cpp(24) : error C2588: '::~SingleLink' : illegal global destructor
e:\workspace\slink\singlelink.cpp(24) : fatal error C1903: unable to recover from previous error(s); stopping compilation
Error executing cl.exe.

SLink.obj - 6 error(s), 0 warning(s)
...全文
108 13 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
mayulin110 2008-11-12
  • 打赏
  • 举报
回复
放到一个头文件中可以调试通过,但如何改才能使定义和实现分离,因为我打算在这个基础上在进行一些扩充
太乙 2008-11-12
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 mayulin110 的回复:]
除了那个头文件的问题,其他的都改了,单还是编译的时候没问题,连接的的时候报错那些错误!
感觉是实例化的时候出了问题,不知道问题在什么地方
[/Quote]



拿到一个.h文件里还报错?

就像我六楼代码一样?

我六楼代码可没错!

mayulin110 2008-11-12
  • 打赏
  • 举报
回复
除了那个头文件的问题,其他的都改了,单还是编译的时候没问题,连接的的时候报错那些错误!
感觉是实例化的时候出了问题,不知道问题在什么地方
太乙 2008-11-12
  • 打赏
  • 举报
回复



模板的定义和实现支持不好~~~

最好别分开!


.h:

#ifndef CLASSDEF
#define CLASSDEF
#include <iostream>
using namespace std;

template <class type> class SingleLink;

template <class T>
class Node
{
public:
friend class SingleLink <T>;
T data;
Node *Next;
};

template <class type>
class SingleLink
{
public:
SingleLink();
virtual ~SingleLink();

bool insert(type Element);//在当前位置插入值
private:
Node <type> *pHead,*pCurNode,*ptemp;
};
//#include"mycpp.cpp"
template <class type>
SingleLink <type>::SingleLink()
{//creat a head node
pHead = pCurNode = ptemp = new Node <type>;
pHead->Next = NULL;
}

template <class type>
SingleLink <type>::~SingleLink()
{
pCurNode = pHead;
while(pCurNode)
{
pHead = pHead->Next;
delete pCurNode;
pCurNode = pHead;
}
}

template <class type>
bool SingleLink <type>::insert(type element)
{//insert the element into current position
if(!pCurNode)
return false;//no link because no head node
else// insert the element into current position
{
ptemp = pCurNode->Next;

pCurNode = pCurNode->Next = new Node <type>;
pCurNode->data = element;
pCurNode->Next = ptemp;
}
return true;
}

#endif




main.cpp

#include "head.h"

int main(int argc, char* argv[])
{
int a[5] = {1,2,3,4,5};
SingleLink <int> linklist;

for(int i = 0; i < 5; i++)
{
linklist.insert(a[i]);
}
return 0;
}





太乙 2008-11-12
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 mayulin110 的回复:]

pHead = pCurNode = ptemp = new Node <type>; //这里写错了!!
要分配一个Node 类型的节点作为头节点,在这个地方怎么写?
[/Quote]


你以前写的是:

pHead = pCurNode = ptemp = new Node <Type>;



mayulin110 2008-11-12
  • 打赏
  • 举报
回复
谢谢
太乙 2008-11-12
  • 打赏
  • 举报
回复



帮你查了一下;

http://topic.csdn.net/u/20071026/15/fad0132c-692a-4c61-8e87-0bfabd0beba4.html

http://www.cnblogs.com/chio/archive/2007/09/08/886390.html




太乙 2008-11-12
  • 打赏
  • 举报
回复
我试了一下,不是很好使~~
太乙 2008-11-12
  • 打赏
  • 举报
回复
http://hi.baidu.com/beckbeckham/blog/item/24bff8454527d73886947317.html
mayulin110 2008-11-11
  • 打赏
  • 举报
回复
pHead = pCurNode = ptemp = new Node <type>; //这里写错了!!
要分配一个Node 类型的节点作为头节点,在这个地方怎么写?
如果把#include "SingleLink.cpp"放在头文件的末尾,编译的时候会报错
fatal error C1004: unexpected end of file found
mayulin110 2008-11-11
  • 打赏
  • 举报
回复

pHead = pCurNode = ptemp = new Node <type>; //这里写错了!!
要分配一个Node 类型的节点作为头节点,在这个地方怎么写?
太乙 2008-11-11
  • 打赏
  • 举报
回复

还有啊:

#include "SingleLink.cpp"

这不在.cpp里这么用

如果要实现模板类的定义和实现分离,可以在类定义的头文件末尾加上:

#include "SingleLink.cpp"

当然,这只是在vc6.0下能行,其他编译器,不敢说!






太乙 2008-11-11
  • 打赏
  • 举报
回复
#include <iostream> 
using namespace std;

template <class type> class SingleLink;

template <class T>
class Node
{
public:
friend class SingleLink <T>;
T data;
Node *Next; //这里直接Node就行!
};

template <class type>
class SingleLink
{
public:
SingleLink();
virtual ~SingleLink();

bool insert(type Element);//在当前位置插入值
private:
Node <type> *pHead,*pCurNode,*ptemp;
};


template <class type>
SingleLink <type>::SingleLink()
{//creat a head node
pHead = pCurNode = ptemp = new Node <type>; //这里写错了!!
pHead->Next = NULL;
}

template <class type>
SingleLink <type>::~SingleLink()
{
pCurNode = pHead;
while(pCurNode)
{
pHead = pHead->Next;
delete pCurNode;
pCurNode = pHead;
}
}

template <class type>
bool SingleLink <type>::insert(type element)
{//insert the element into current position
if(!pCurNode)
return false;//no link because no head node
else// insert the element into current position
{
ptemp = pCurNode->Next;

pCurNode = pCurNode->Next = new Node <type>;
pCurNode->data = element; //这里没有data
pCurNode->Next = ptemp;
}
return true;
}

int main(int argc, char* argv[])
{
int a[5] = {1,2,3,4,5};
SingleLink <int> linklist;

for(int i = 0; i < 5; i++)
{
linklist.insert(a[i]);
}
return 0;
}
资源下载链接为: https://pan.quark.cn/s/abbae039bf2a 在计算机视觉领域,实时目标跟踪是许多应用的核心任务,例如监控系统、自动驾驶汽车和无人机导航等。本文将重点介绍一种在2017年备受关注的高效目标跟踪算法——BACF(Boosted Adaptive Clustering Filter)。该算法因其卓越的实时性和高精度而脱颖而出,其核心代码是用MATLAB编写的。 BACF算法全称为Boosted Adaptive Clustering Filter,是基于卡尔曼滤波器改进的一种算法。传统卡尔曼滤波在处理复杂背景和目标形变时存在局限性,而BACF通过引入自适应聚类和Boosting策略,显著提升了对目标特征的捕获和跟踪能力。 自适应聚类是BACF算法的关键技术之一。它通过动态更新特征空间中的聚类中心,更准确地捕捉目标的外观变化,从而在光照变化、遮挡和目标形变等复杂情况下保持跟踪的稳定性。此外,BACF还采用了Boosting策略。Boosting是一种集成学习方法,通过组合多个弱分类器形成强分类器。在BACF中,Boosting用于优化目标检测性能,动态调整特征权重,强化对目标识别贡献大的特征,从而提高跟踪精度。BACF算法在设计时充分考虑了计算效率,能够在保持高精度的同时实现快速实时的目标跟踪,这对于需要快速响应的应用场景(如视频监控和自动驾驶)至关重要。 MATLAB作为一种强大的数学计算和数据分析工具,非常适合用于算法的原型开发和测试。BACF算法的MATLAB实现提供了清晰的代码结构,方便研究人员理解其工作原理并进行优化和扩展。通常,BACF的MATLAB源码包含以下部分:主函数(实现整个跟踪算法的核心代码)、特征提取模块(从视频帧中提取目标特征的子程序)、聚类算法(实现自适应聚类过程)、Boosting算法(包含特征权重更新的代
内容概要:本书《Deep Reinforcement Learning with Guaranteed Performance》探讨了基于李雅普诺夫方法的深度强化学习及其在非线性系统最优控制中的应用。书中提出了一种近似最优自适应控制方法,结合泰勒展开、神经网络、估计器设计及滑模控制思想,解决了不同场景下的跟踪控制问题。该方法不仅保证了性能指标的渐近收敛,还确保了跟踪误差的渐近收敛至零。此外,书中还涉及了执行器饱和、冗余解析等问题,并提出了新的冗余解析方法,验证了所提方法的有效性和优越性。 适合人群:研究生及以上学历的研究人员,特别是从事自适应/最优控制、机器人学和动态神经网络领域的学术界和工业界研究人员。 使用场景及目标:①研究非线性系统的最优控制问题,特别是在存在输入约束和系统动力学的情况下;②解决带有参数不确定性的线性和非线性系统的跟踪控制问题;③探索基于李雅普诺夫方法的深度强化学习在非线性系统控制中的应用;④设计和验证针对冗余机械臂的新型冗余解析方法。 其他说明:本书分为七章,每章内容相对独立,便于读者理解。书中不仅提供了理论分析,还通过实际应用(如欠驱动船舶、冗余机械臂)验证了所提方法的有效性。此外,作者鼓励读者通过仿真和实验进一步验证书中提出的理论和技术。

65,186

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧