当前位置: 首页 > news >正文

类模板的使用方法

目录

类模板的使用方法

1.类模板语法

2.类模板和函数模板区别

3.类模板中成员函数创建时机

4.类函数对象做函数参数

5.类模板和继承

6.类模板成员函数类外实现

7.类模板分文件编写

person.hpp

实现cpp文件:

8.类模板与友元

9.类模板案例

MyArray.hpp

在Cpp文件中展示方式:


类模板的使用方法

1.类模板语法

类模板作用:

建立一个通用类,类中的成员 数据类型可以不具体制定,用一个虚拟的类型来代表。语法:

template<typename T>


解释:

template - 声明创建模板

typename - 表面其后面的符号是一种数据类型,可以用class代替

T - 通用的数据类型,名称可以替换,通常为大写字母

#include<iostream>
using namespace std;
#include<string>

template<class NameType,class AgeType>
class Person
{
public:
    Person(NameType name,AgeType age)
    {
        this->m_name = name;
        this->m_age = age;
    }

    void ShowPerson()
    {
        cout << "name:" << m_name << ",age:" << m_age << endl;
    }
    NameType m_name;
    AgeType m_age;
};

void test01()
{
    Person<string, int> p1("猴子", 500);
    p1.ShowPerson();
}

//类模板和函数模板相似,在声明模板template后面加类,此类称为类模板

int main()
{
    test01();

    system("pause");

    return 0;
}

2.类模板和函数模板区别

类模板与函数模板区别主要有两点:

1.类模板没有自动类型推导的使用方式

2.类模板在模板参数列表中可以有默认参数

#include <iostream>
using namespace std;
#include<string>
template<class NameType,class AgeType = int>
class Person
{
public:
    Person(NameType name, AgeType age)
    {
        this->m_name = name;
        this->m_age = age;
    }
    void PrintPeson()
    {
        cout << "name:" << m_name << ",age:" << m_age << endl;
    }
    NameType m_name;
    AgeType m_age;
};

//1、类模板没有自动类型推导使用方式
void test01()
{
    //Person p("八戒", 900); 错误,无法用自动类型推导
    Person<string, int> p1("八戒", 900);
    p1.PrintPeson();
}
//2、类模板在模板参数列表中可以有默认参数
void test02()
{
    Person<string> p1("八戒", 900);
    p1.PrintPeson();
}
int main()
{
    test02();
    return 0;
}

3.类模板中成员函数创建时机

类模板中成员函数和普通类中成员函数创建时机是有区别的

普通类中的成员函数一开始就可以创建

类模板中的成员函数在调用时才创建

#include <iostream>
using namespace std;class Person1
{
public:Person1(){}void showPerson1(){cout << "调用的Person1" << endl;}
};class Person2
{
public:void showPerson2(){cout << "调用的Persona2" << endl;}
};template<class T>
class MyClass
{
public:T obj;void fun1() { obj.showPerson1(); }void fun2() { obj.showPerson2(); }
};
//类模板中的成员函数并不是一开始就创建的,在调用时才会去创建
void Test01()
{MyClass<Person1> m;m.fun1();// m.fun2();//编译会出错,说明函数调用才会去创建成员函数
}
int main()
{Test01();
}

4.类函数对象做函数参数

类模板实例化出的对象,向函数传参的方式

一共有三种传入方式:

1.指定传入的类型!——直接显示对象的数据类型

2.参数模板化——将对象中的参数变为模板进行传递

3.整个类模板化——将这个对象类型 模板化进行传递

#include <iostream>
using namespace std;
#include<string>template<class T1,class T2>
class Person
{
public:Person(T1 name,T2 age){this->m_name = name;this->m_age = age;}void ShowPerson(){cout << "姓名:" << this->m_name << " 年龄:" << this->m_age << endl;}T1 m_name;T2 m_age;
};//1、指定传入类型
void printPerson1(Person<string,int>&p)
{p.ShowPerson();
}void test01()
{Person<string, int> p1("高手", 2);printPerson1(p1);
}//2、参数模板化
template<class T1,class T2>
void printPerson2(Person<T1, T2> &p)
{p.ShowPerson();cout << "T1 的类型为" << typeid(T1).name() << endl;cout << "T2 的类型为" << typeid(T2).name() << endl;
}void test02()
{Person<string, int> p2("高高手", 2);printPerson2(p2);
}//3、整个类模板化
template<class T>
void printPerson3(T& p)
{p.ShowPerson();cout << "T的数据类型为:" << typeid(T).name() << endl;
}void test03()
{Person<string, int> p3("高高高手", 5);printPerson3(p3);
}//通过类模板创建的对象,向函数中进行传参,使用比较广泛的是第一种:指定传入的类型
int main()
{test03();
}

5.类模板和继承

当子类继承的父类是一个类模板时,子类在声明的时候,要指定出父类中T的类型

如果不指定,编译器无法给子类分配内存

如果想灵活指定出父类中T的类型,子类也需变为类模板

#include <iostream>
using namespace std;//类模板与继承
template<class T>
class Base
{T m;
};//class Son1 :Base  错误,必须知道父类中的T类型,才能继承给子类
class Son:Base<int>
{};void test01()
{// Son S1;
}//如果想灵活指定父类中T类型,子类也需要变类模板
template<class T1,class T2>
class Son2 :public Base<T2>
{
public:Son2(){cout << "T1的类型为:" << typeid(T1).name() << endl;cout << "T2的类型为:" << typeid(T2).name() << endl;}T1 obj;
};void test02()
{Son2<int,char>S2;}
//总结:如果父类是类模板,子类需要指定出父类中T的数据类型
int main()
{test02();
}

6.类模板成员函数类外实现

#include <iostream>
#include<string>
using namespace std;//类模板成员函数类外实现
template<class T1,class T2>
class Person
{
public:Person(T1 name, T2 age);/*  {this->m_name = name;this->m_age = age;}*/void showPerson();/* {cout << "姓名: " << this.m_name << ",年龄: " << this.m_age << endl;}*/T1 m_name;T2 m_age;
};//构造函数类外实现
template<class T1,class T2>
Person<T1, T2>::Person(T1 name, T2 age)
{this->m_name = name;this->m_age = age;
}//模板成员函数类外实现
template<class T1,class T2>
void Person<T1,T2>::showPerson()
{cout << "姓名:" << this->m_name << ",年龄:" << this->m_age << endl;
}void test01()
{Person<string,int>p1("猴子",200);p1.showPerson();
}//总结:类模板中成员函数类外实现时,需要加上模板参数列表
int main()
{test01();
}

7.类模板分文件编写

类模板中成员函数创建时机是在调用阶段,导致分文件编写时链接不到

解决方式1:直接包含.cpp源文件

解决方式2:将声明和实现写到同一个文件中,并更改后缀名为.hpp,hpp是约定的名称,并不是强制

person.hpp

#pragma once
#include<iostream>
#include<string>
using namespace std;
template<class T1, class T2>
class Person
{
public:Person(T1 name, T2 age);void showPerson();T1 m_name;T2 m_age;
};template<class T1, class T2>
Person<T1, T2>::Person(T1 name, T2 age)
{this->m_name = name;this->m_age = age;
}template<class T1, class T2>
void Person<T1, T2>::showPerson()
{cout << "姓名:" << this->m_name << ",年龄:" << this->m_age << endl;
}

实现cpp文件:

#include <iostream>
#include<string>
using namespace std;//类模板分文件编写问题以及解决//第一种解决方法,直接包含源文件
//#include"person.cpp"//第二种解决方法,将.h和.cpp中的内容写到一起,将后缀名改为.hpp文件
#include"person.hpp"void test01()
{Person<string, int> p1("沙僧", 200);p1.showPerson();
}
// 总结:主流的解决方式是第二种,将类模板成员函数写到一起,并将后缀名改为.hpp
int main()
{test01();
}

8.类模板与友元

全局函数类内实现——直接在类内声明友元即可

全局函数类外实现——需要提前让编译器知道全局函数的存在

#include <iostream>
#include<string>
using namespace std;template<class T1,class T2>
class Person;
//全局函数类外实现
template<class t1, class t2>
void printPerson2(Person<t1, t2> p)
{cout << "类外实现——姓名: " << p.m_Name << "类外实现——年龄:" << p.m_Age << endl;
}template<class T1,class T2>
class Person
{//全局函数 类内实现friend void printPerson(Person<T1, T2> p){cout << "姓名: " << p.m_Name << "年龄:" << p.m_Age << endl;}//全局函数 类外实现//加空模板参数列表//如果全局函数 是类外实现,需要让编译器提前知道这个函数的存在friend void printPerson2<>(Person<T1, T2>);public:Person(T1 name, T2 age){this->m_Name = name;this->m_Age = age;}
private:T1 m_Name;T2 m_Age;
};//1.全局函数在类内实现
void test01()
{Person<string, int>p("僧人", 21);printPerson(p);
}
//2.全局函数类外实现
void test02()
{Person<string, int>p("僧人2", 22);printPerson2(p);
}
//总结:建议全局函数做类内实现,用法简单,而且编译器可以直接识别int main()
{test02();
}

9.类模板案例

具体实现功能:

1.可以对内置数据类型以及自定义数据类型的数据进行存储
2.将数组中的数据存储到堆区
3.构造函数中可以传入数组的容量
4.提供对应的拷贝构造函数以及operator = 防止浅拷贝问题
5.提供尾插法和尾删法对数组中的数据进行增加和删除
6.可以通过下标的方式访问数组中的元素
7.可以获取数组中当前元素个数和数组的容量

MyArray.hpp

//自己的通用的数组类
#pragma once
#include<iostream>
using namespace std;/*1.可以对内置数据类型以及自定义数据类型的数据进行存储
2.将数组中的数据存储到堆区
3.构造函数中可以传入数组的容量
4.提供对应的拷贝构造函数以及operator = 防止浅拷贝问题
5.提供尾插法和尾删法对数组中的数据进行增加和删除
6.可以通过下标的方式访问数组中的元素
7.可以获取数组中当前元素个数和数组的容量*/
template<class T>
class MyArray
{
public://有参构造 参数 容量MyArray(int capacity){//cout << "MyArray的有参构造调用" << endl;this->m_Capacity = capacity;this->m_Size = 0;this->pAddress = new T[this->m_Capacity];}//拷贝构造MyArray(const MyArray& arr){//cout << "MyArray的拷贝构造调用" << endl;this->m_Capacity = arr.m_Capacity;this->m_Size = arr.m_Size;//this->pAddress = arr.pAddress;  浅拷贝会导致堆区的值冲突//深拷贝this->pAddress = new T[m_Capacity];//将arr中的数据都拷贝过来for (int i = 0; i < arr.m_Size; i++){this->pAddress[i] = arr.pAddress[i];}}//operator= 防止浅拷贝问题 a=b=cMyArray& operator=(const MyArray& arr){//cout << "MyArray的 operator= 函数调用" << endl;//先判断原来堆区是否有数据,如果有先释放if (this->pAddress!=NULL){delete[] this->pAddress;this->pAddress = NULL;this->m_Capacity = 0;this->m_Size = 0;}//深拷贝this->m_Capacity = arr.m_Capacity;this->m_Size = arr.m_Size;this->pAddress = new T[arr.m_Capacity];for (int i=0;i<arr.m_Size;i++){this->pAddress[i] = arr.pAddress[i];}return *this;}//尾插法void Push_Back(const T& val){//判断容量是否等于大小if (this->m_Capacity==this->m_Size){return;}this->pAddress[this->m_Size] = val;//在数组末尾插入数据this->m_Size++;//更新数组大小}//尾删法void Pop_Back(){//让用户访问不到最后一个元素,即为尾删,逻辑删除if (this->m_Size == 0){return;}this->m_Size--;}//通过下标方式来访问数组中的元素 arr[0]=100T& operator[](int index){return this->pAddress[index];}//返回数组容量int getCapacity(){return this->m_Capacity;}//返回数组大小int getSize(){return this->m_Size;}//析构函数~MyArray(){if (this->pAddress!=NULL){//cout << "MyArray的析构函数调用" << endl;delete[] this->pAddress;this->pAddress = NULL;}}private:T* pAddress;//指针指向堆区开辟的真实数组int m_Capacity;//数组容量int m_Size;//数组大小
};

在Cpp文件中展示方式:

#include <iostream>
using namespace std;
#include"MyArray.hpp"
#include<string>
void printArray(MyArray<int> &arr)
{for (int i = 0; i < arr.getSize(); i++){cout << arr[i] << endl;}
}void Test01()
{MyArray<int> arr1(5);//有参构造for (int i = 0; i < 5; i++){//利用尾插法向数组中插入数据arr1.Push_Back(i);}cout << "arr1的打印输出为:" << endl;printArray(arr1);cout << "arr1的容量为:" << arr1.getCapacity() << endl;cout << "arr1的大小为:" << arr1.getSize() << endl;MyArray<int> arr2(arr1);  //深拷贝cout << "arr2的打印输出为:" << endl;printArray(arr2);arr2.Pop_Back();cout << "arr2尾删后:" << endl;cout << "arr2的容量为:" << arr2.getCapacity() << endl;cout << "arr2的大小为:" << arr2.getSize() << endl;// MyArray<int>arr3(100);//有参构造// arr3 = arr1; //operator= 调用
}class Person
{
public:Person(){};Person(string name, int age){this->m_Name = name;this->m_Age = age;}string m_Name;int m_Age;
};
void PrintPersonArray(MyArray<Person> &arr)
{for (int i = 0; i < arr.getSize(); i++){cout << "姓名:" << arr[i].m_Name << ",年龄:" << arr[i].m_Age << endl;}
}
void Test02()
{MyArray<Person> arr(10);Person p1("开天", 1);Person p2("裂地", 2);Person p3("劈天", 3);Person p4("裂天", 4);Person p5("封天", 5);Person p6("震地", 6);//将数据插入到数组中arr.Push_Back(p1);arr.Push_Back(p2);arr.Push_Back(p3);arr.Push_Back(p4);arr.Push_Back(p5);arr.Push_Back(p6);PrintPersonArray(arr);//输出容量cout <<"arr容量为:" << arr.getCapacity() << endl;//输出大小cout << "arr大小为:" << arr.getSize() << endl;}
int main()
{Test02();
}//总结:能够利用所学知识点实现通用的数组

相关文章:

类模板的使用方法

目录 类模板的使用方法 1.类模板语法 2.类模板和函数模板区别 3.类模板中成员函数创建时机 4.类函数对象做函数参数 5.类模板和继承 6.类模板成员函数类外实现 7.类模板分文件编写 person.hpp 实现cpp文件&#xff1a; 8.类模板与友元 9.类模板案例 MyArray.hpp …...

高级Python Web开发:FastAPI的前后端集成与API性能优化

高级Python Web开发&#xff1a;FastAPI的前后端集成与API性能优化 目录 &#x1f6e0;️ 前后端集成的基本原理与实践&#x1f680; FastAPI的API设计与实现&#x1f4c8; API性能测试与负载测试 &#x1f4ca; 使用Locust进行API性能测试&#x1f4a5; 使用Apache JMeter进…...

期权懂|期权的溢价率和杠杆率有什么区别?

锦鲤三三每日分享期权知识&#xff0c;帮助期权新手及时有效地掌握即市趋势与新资讯&#xff01; 期权的溢价率和杠杆率有什么区别&#xff1f; 一、定义篇 期权溢价率&#xff1a;这是一个细腻地描绘了期权价格与其内在价值之间微妙差异的指标。想象一下&#xff0c;期权价格就…...

分布式ID的实现方案

1. 什么是分布式ID ​ 对于低访问量的系统来说&#xff0c;无需对数据库进行分库分表&#xff0c;单库单表完全可以应对&#xff0c;但是随着系统访问量的上升&#xff0c;单表单库的访问压力逐渐增大&#xff0c;这时候就需要采用分库分表的方案&#xff0c;来缓解压力。 ​…...

Py之cv2:cv2(OpenCV,opencv-python)库的简介、安装、使用方法(常见函数、图像基本运算等)

1. OpenCV简介 1.1 OpenCV定义与功能 OpenCV&#xff08;Open Source Computer Vision Library&#xff09;是一个开源的计算机视觉和机器学习软件库。它为计算机视觉应用程序提供了一个通用的基础设施&#xff0c;并加速了在商业产品中使用机器感知。作为BSD许可的产品&…...

如何学习网络安全?有哪些小窍门?

学好网络安全其实没有所谓的捷径&#xff0c;也没有什么小窍门。 入门网络安全首先要有浓厚的学习兴趣&#xff0c;不然很容易就变成了从入门到放弃了。 其次要能静下心&#xff0c;踏踏实实的打好基础。如果你是零基础&#xff0c;建议从Web安全入手&#xff0c;课程难度相对…...

Dart语言的数据结构

Dart语言中的数据结构探讨 引言 Dart是一种现代化的编程语言&#xff0c;主要用于构建移动应用、Web应用和服务端应用。随着应用程序的复杂性日益增加&#xff0c;选择合适的数据结构显得尤为重要。数据结构不仅影响程序的性能&#xff0c;也影响程序的可维护性和可扩展性。本…...

TabPFN - 表格数据基础模型

文章目录 一、关于 TabPFN&#x1f310;TabPFN生态系统 二、快速入门&#x1f3c1;1、安装2、基本用法 三、使用技巧&#x1f4a1;四、开发&#x1f6e0;️1、设置环境2、在提交之前3、运行测试 一、关于 TabPFN TabPFN是表格数据的基础模型&#xff0c;它优于传统方法&#x…...

AOF日志:宕机了Redis如何避免数据丢失?

文章目录 AOF 日志是如何实现的&#xff1f;三种写回策略日志文件太大了怎么办&#xff1f;AOF 重写会阻塞吗?小结每课一问 更多redis相关知识 如果有人问你&#xff1a;“你会把 Redis 用在什么业务场景下&#xff1f;”我想你大概率会说&#xff1a;“我会把它当作缓存使用&…...

MAC上安装Octave

1. 当前最新版Octave是9.3版本&#xff0c;需要把mac os系统升级到14版本&#xff08;本人之前的版本是10版本&#xff09; https://wiki.octave.org/Octave_for_macOS octave的历史版本参考此文档&#xff1a;Octave for macOS (outdated) - Octavehttps://wiki.octave.org/Oc…...

C 语言中二维数组的退化

目录 1. 一维数组的退化 2.字符串数组的退化 3. 二维数组的退化 3.1 为什么退化为 int (*)[4] 而不是 int **&#xff1f; 3.2举例说明 3.3 .总结 在 C 语言中&#xff0c;数组名在大多数情况下会退化为指向其第一个元素的指针&#xff0c;这种机制称为数组退化&#xf…...

Notion 推出捏脸应用 | Deving Weekly #15

CEF-Detector-X 现在 Chromium 占据了桌面应用的大壁江山&#xff0c;典型的有 Electron 框架&#xff0c;底层就是基于 Chromium 内核&#xff0c;上百 M 的臃肿包体积一直别人诟病。 CEF-Detector-X 可以检测你电脑有多少个 基于 Chromium 应用&#xff0c;并且会生成一份「…...

C# Linq 查询

1.Linq 查询表达式基础 Linq 查询应用程序始终将源数据视为 IEnumerable<T> 或 IQueryable<T> 集合。 LINQ查询表达式包含8个基本子句,分别为from、select、group、where、orderby、join、let和into。 子 句备注from指定数据源和范围变量select指定当执行查询…...

ES7【2016】、ES8【2017】新增特性

ES7【2016】新增特性 幂指数操作符 在ES7【2016】中新增了幂指数操作&#xff0c;幂指数操作符是**。它用于指数计算 基本语法&#xff1a;baseValue ** exponent 参数说明&#xff1a;baseValue是基数&#xff0c;exponent是指数。 let base 2; let exponent 4; let resul…...

64细分步进电机驱动器TMC2209

封装和丝印 典型电路1 典型电路2 应用 兼容设计升级 3D 打印机 打印机、POS 办公和家庭自动化 纺织、缝纫机 闭路电视&#xff0c; 安保 ATM&#xff0c; 现金回收机 暖 通 空调 电池供电设备 特点和优势 2 相步进电机&#xff0c;线圈电流&#xff08;峰值&#xff09;高达…...

C# 获取PDF文档中的字体信息(字体名、大小、颜色、样式等

在设计和出版行业中&#xff0c;字体的选择和使用对最终作品的质量有着重要影响。然而&#xff0c;有时我们可能会遇到包含未知字体的PDF文件&#xff0c;这使得我们无法准确地复制或修改文档。获取PDF中的字体信息可以解决这个问题&#xff0c;让我们能够更好地处理这些文件。…...

linux 安装PrometheusAlert配置钉钉告警

在 Linux 上安装 PrometheusAlert 并配置钉钉告警的步骤如下: 1. 准备工作 钉钉机器人: 在钉钉群中创建一个机器人,获取 Webhook URL。示例 Webhook URL:https://oapi.dingtalk.com/robot/send?access_token=your_dingtalk_token。PrometheusAlert 安装包: 从 Prometheus…...

【华为路由/交换机的ssh远程设置】

华为路由/交换机的ssh远程设置 R1&#xff08;client&#xff09;&#xff1a;10.1.1.1 R2&#xff08;server&#xff09;&#xff1a;10.1.1.2 R2服务端配置&#xff1a; 生成本机密钥 查看生成的密钥 设置AAA授权验证方式&#xff0c;并设置支持SSH协议 创建本地用户&…...

性能测试 - Locust WebSocket client

Max.Bai 2024.10 0. 背景 Locust 是性能测试工具&#xff0c;但是默认只支持http协议&#xff0c;就是默认只有http的client&#xff0c;需要其他协议的测试必须自己扩展对于的client&#xff0c;比如下面的WebSocket client。 1. WebSocket test Client “”“ Max.Bai W…...

html中鼠标位置信息

pageX&#xff1a;鼠标距离页面的最左边的距离&#xff0c;包括滚动条的长度。clientX&#xff1a;鼠标距离浏览器视口的左距离&#xff0c;不包括滚动条。offsetX&#xff1a;鼠标到事件源左边的距离。movementX&#xff1a;鼠标这次触发的事件的位置相对于上一次触发事件的位…...

Android Wi-Fi 连接失败日志分析

1. Android wifi 关键日志总结 (1) Wi-Fi 断开 (CTRL-EVENT-DISCONNECTED reason3) 日志相关部分&#xff1a; 06-05 10:48:40.987 943 943 I wpa_supplicant: wlan0: CTRL-EVENT-DISCONNECTED bssid44:9b:c1:57:a8:90 reason3 locally_generated1解析&#xff1a; CTR…...

Leetcode 3577. Count the Number of Computer Unlocking Permutations

Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接&#xff1a;3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯&#xff0c;要想要能够将所有的电脑解锁&#x…...

现代密码学 | 椭圆曲线密码学—附py代码

Elliptic Curve Cryptography 椭圆曲线密码学&#xff08;ECC&#xff09;是一种基于有限域上椭圆曲线数学特性的公钥加密技术。其核心原理涉及椭圆曲线的代数性质、离散对数问题以及有限域上的运算。 椭圆曲线密码学是多种数字签名算法的基础&#xff0c;例如椭圆曲线数字签…...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词

Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵&#xff0c;其中每行&#xff0c;每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid&#xff0c;其中有多少个 3 3 的 “幻方” 子矩阵&am…...

论文笔记——相干体技术在裂缝预测中的应用研究

目录 相关地震知识补充地震数据的认识地震几何属性 相干体算法定义基本原理第一代相干体技术&#xff1a;基于互相关的相干体技术&#xff08;Correlation&#xff09;第二代相干体技术&#xff1a;基于相似的相干体技术&#xff08;Semblance&#xff09;基于多道相似的相干体…...

C++.OpenGL (14/64)多光源(Multiple Lights)

多光源(Multiple Lights) 多光源渲染技术概览 #mermaid-svg-3L5e5gGn76TNh7Lq {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-3L5e5gGn76TNh7Lq .error-icon{fill:#552222;}#mermaid-svg-3L5e5gGn76TNh7Lq .erro…...

基于IDIG-GAN的小样本电机轴承故障诊断

目录 🔍 核心问题 一、IDIG-GAN模型原理 1. 整体架构 2. 核心创新点 (1) ​梯度归一化(Gradient Normalization)​​ (2) ​判别器梯度间隙正则化(Discriminator Gradient Gap Regularization)​​ (3) ​自注意力机制(Self-Attention)​​ 3. 完整损失函数 二…...

C++课设:简易日历程序(支持传统节假日 + 二十四节气 + 个人纪念日管理)

名人说:路漫漫其修远兮,吾将上下而求索。—— 屈原《离骚》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 专栏介绍:《编程项目实战》 目录 一、为什么要开发一个日历程序?1. 深入理解时间算法2. 练习面向对象设计3. 学习数据结构应用二、核心算法深度解析…...

群晖NAS如何在虚拟机创建飞牛NAS

套件中心下载安装Virtual Machine Manager 创建虚拟机 配置虚拟机 飞牛官网下载 https://iso.liveupdate.fnnas.com/x86_64/trim/fnos-0.9.2-863.iso 群晖NAS如何在虚拟机创建飞牛NAS - 个人信息分享...

Python 训练营打卡 Day 47

注意力热力图可视化 在day 46代码的基础上&#xff0c;对比不同卷积层热力图可视化的结果 import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms from torch.utils.data import DataLoader import matplotlib.pypl…...