my stl study-road<template>

模板的定义:

  template <class TYPE>

  template <typename T, int SIZE>   //typename可以替代class声明模板


多参数,带缺省值得:

  template <class TYPE,class ARG=vector<TYPE> >

  如果只传给它一个参数,缺省参数可以作为第二参数使用.

关键字typename

  typename 被作为型别之前的标识符号。

 eg:

  1. #include <iostream>  
  2. #include "MyClass.h"  
  3.   
  4. using namespace std;  
  5.   
  6. class Q{  
  7. public:  
  8.         typedef int SubType;  
  9. };  
  10. int main()  
  11. {  
  12.     cout << "Hello world!" << endl;  
  13.     MyClass<Q> x;  
  14.   
  15.     return 0;  
  16. }  


-----------MyClass.h------------

  1. template<class T>  
  2. class MyClass  
  3. {  
  4.         public:  
  5.                 MyClass();  
  6.                 ~MyClass();  
  7.                 MyClass(const MyClass& other);  
  8.                 void printf();  
  9.         protected:  
  10.         private:  
  11.                 typename T::SubType * ptr;  
  12. };  


说明:Subtype成为一个型别的必要条件是:

任何一个用来取代T的型别,其内部必须提供SubType的定义.


模板类的拷贝构造(缺省)和模板构造:

  1. #ifndef MYCLASS_H  
  2. #define MYCLASS_H  
  3.   
  4. template<class T>  
  5. class MyClass  
  6. {  
  7.         public:  
  8.                 MyClass();  
  9.                 ~MyClass();  
  10.                 //MyClass(const MyClass& other);  
  11.                 template<class X>  
  12.                 MyClass(const MyClass<X>& other)  
  13.                 {  
  14.                         //copy ctor  
  15.                         ptr=other.getvalue();  
  16.                 }  
  17.                 T getvalue() const  
  18.                 {  
  19.                         return ptr;  
  20.                 }  
  21. //                MyClass(const MyClass& other)  
  22. //                {  
  23. //                        //copy ctor  
  24. //                        ptr=other;  
  25. //                }  
  26.   
  27.                 void printf();  
  28.         protected:  
  29.         private:  
  30.                  T ptr;  
  31. };  

--------------main----------------------
  1. int main()  
  2. {  
  3.     cout << "Hello world!" << endl;  
  4.     MyClass<int> x;  
  5.     MyClass<double> y(x);  
  6.   
  7.     return 0;  
  8. }  
如果不用 Myclass<X>,则main函数里面是报错的。即使有隐含的double到int类型的强制转化。

而加了Myclass<X>则轻松解决了这一问题。值得注意的是,这里没有用:ptr=other.ptr的原因:

ptr是类的私有成员变量,这里是在 MyClass<T>里面,只能调用T的ptr,X的ptr在T内是不可见的。所以这里用到了getvalue函数。




显示初始化:

int i1;

int i2=int();


template <class T>

void f()

{

     T x=T();

}

//调用的是缺省的构造函数.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像中所有感兴趣的目标(物体),并确定它们的类别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像中目标的位置并识别出目标的类别。由于各类物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分类问题:判断图像中的目标属于哪个类别。 定位问题:确定目标在图像中的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分类 基于深度学习的目标检测算法主要分为两大类: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分类。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络中提取特征来预测物体分类和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和类别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
下面是一个简单的Set模板类的实现,并重载了+,-,<<和>>操作符: ```c++ #include <iostream> #include <set> template<typename T> class Set { public: Set() {} Set(const std::set<T>& s) : data(s) {} Set<T> operator+(const Set<T>& rhs) const { std::set<T> result(data); for (auto it = rhs.data.begin(); it != rhs.data.end(); ++it) { result.insert(*it); } return Set<T>(result); } Set<T> operator-(const Set<T>& rhs) const { std::set<T> result(data); for (auto it = rhs.data.begin(); it != rhs.data.end(); ++it) { result.erase(*it); } return Set<T>(result); } friend std::ostream& operator<<(std::ostream& os, const Set<T>& s) { os << "{ "; for (auto it = s.data.begin(); it != s.data.end(); ++it) { os << *it << " "; } os << "}"; return os; } friend std::istream& operator>>(std::istream& is, Set<T>& s) { T value; while (is >> value) { s.data.insert(value); } return is; } private: std::set<T> data; }; int main() { Set<int> s1, s2; std::cout << "Enter values for set 1: "; std::cin >> s1; std::cout << "Enter values for set 2: "; std::cin >> s2; std::cout << "Set 1: " << s1 << std::endl; std::cout << "Set 2: " << s2 << std::endl; std::cout << "Set 1 + Set 2: " << s1 + s2 << std::endl; std::cout << "Set 1 - Set 2: " << s1 - s2 << std::endl; return 0; } ``` 在这个示例中,我们使用了STL中的set作为Set的内部数据结构。我们重载了+和-操作符来实现集合的并和差运算。我们还重载了<<和>>操作符,以便可以像使用std::cin和std::cout一样输入和输出Set对象。 注意,在这个示例中,我们假设输入的元素是整数。如果要使用其他类型的元素,需要相应地修改代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值