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

C++11-(2)

文章目录

  • (一)C++11新增功能
    • 1.1 引用折叠
      • 1.1.1 在模板中使用引用折叠的场景
      • 1.1.2 引用折叠是如何实现的
    • 1.2 完美转发
    • 1.3 lambda表达式语法
      • 1.3.1 定义
      • 1.3.2 lambda的使用场景
      • 1.3.3 捕捉列表
      • 1.3.4 mutable语法
      • 1.3.5 lambda的原理

(一)C++11新增功能

1.1 引用折叠

C++中不能直接定义引用的引用,如int& && r = i ;,但是可以间接定义引用的引用,一般情况可以用typedef或者using关键字来实现

int main()
{//int i = 0;//int&&& r = i; //直接定义引用的引用是错误的typedef int& lref;using rref = int&&;int n = 10;//间接引用lref& r1 = n;lref&& r2 = n;rref& r3 = n;rref&& r4 = 1;return 0;
}

上面的代码中,通过模板或者typedef中的类型操作可以构成引用的引用,C++11中把这样的场景叫作引用折叠,它的折叠逻辑是,右值引用的右值引用折叠成右值引用,有左值引用的组合均被折叠成左值引用,所以代码中r1的类型是int&,r2的类型是int&,r3的类型是int&,只有r4的类型是int&&

1.1.1 在模板中使用引用折叠的场景

左值引用模板:

template<class T>
void f1(T& t) 
{ }int main()
{int i = 10;//没有折叠,实例化->f1(int& t);f1<int>(i);f1<int>(0); //报错//有折叠,实例化->f1(int& t);f1<int&>(i);f1<int&&>(0); //报错//有折叠,实例化->f1(int& t);f1<int&&>(i);f1<int&&>(0); //报错//有折叠,实例化->f1(const int& t);f1<const int&>(i);f1<const int&&>(0); //被const修饰的int& 可以引用左值,也可以引用右值return 0;
}

右值引用模板:

template<class T>
void f2(T&& t) //右值引用的模板
{ }int main()
{int i = 10;//没有折叠,实例化->f2(int& t);f2<int>(i);f2<int>(0); //报错//有折叠,实例化->f2(int& t);f2<int&>(i);f2<int&>(0); //报错//有折叠,实例化->f2(int&& t);f2<int&&>(i); //报错f2<int&&>(0);//有折叠,实例化->f2(const int& t);f2<const int&>(i);f2<const int&>(0); //被const修饰的int& 可以引用左值,也可以引用右值return 0;
}

总结:第一个模板为左值引用,由于折叠限定,实例化出来的都是左值引用,第二个模板为右值引用,由于折叠限定,实例化出来的可以为左值引用,也可以为右值引用,即第二个模板通常被称为“万能引用”

1.1.2 引用折叠是如何实现的

证明如下:

template<class T>
void func(T&& t) //右值引用模板
{int a = 0;T x = a;x++;std::cout << &a << std::endl;std::cout << &x << std::endl;
}
int main()
{func(10);//10是右值,则推导出来的T是int,实例化->func(int&& t);//func函数中,x++,a与x的地址不相同int b = 0;func(b);//b是左值,则推导出来的T是int&,实例化->func(int& t);//func函数中,x是a的别名,x++相当于a++,两者地址相同func(std::move(b));//std::move(b)是右值,则推导出来的T是int,实例化->func(int&& t);//func函数中,x++,a与x的地址不相同const int a = 11;func(a);//a是左值,则推导出来的T是const int&,实例化->func(const int& t);// func函数中,x是a的别名,x被const修饰不能进行赋值操作,两者地址相同func(std::move(a));//std::move(a)是右值,则推导出来的T是const int,实例化->func(const int&& t);//func函数中,x被const修饰不能进行赋值操作,两者地址不相同return 0;
}

总结:当实参是左值时,编译器会自动推导模板参数的类型为int&,发生引用折叠,使得左值引用均折叠成左值引用,当实参是右值时,编译器会自动推导模板参数的类型为int,不发生引用折叠,就还是右值引用

1.2 完美转发

看下面代码:

void fun(int& t) { std::cout << "左值引用" << std::endl; };
void fun(const int& t) { std::cout << "const左值引用" << std::endl; };
void fun(int&& t) { std::cout << "右值引用" << std::endl; };
void fun(const int&& t) { std::cout << "const右值引用" << std::endl; };template<class T>
void Func(T&& t)
{fun(t);
}int main()
{Func(10);//右值,推导出来的T为int,实例化->Func(int&& t);int a = 11;Func(a);//左值,推导出来的T为int&,实例化->Func(int& t);Func(std::move(a));//右值,推导出来的T为int,实例化->Func(int&& t);const int b = 22;Func(b);//左值,推导出来的T为const int&,实例化->Func(const int& t);Func(std::move(b));//右值,推导出来的T为const int,实例化->Func(const int&& t);return 0;
}

该代码,通过万能模板调用Func函数,然后再调用fun函数,实现根据不同的值的属性调用到对应的fun函数,如,10是右值就调用对应fun函数的右值引用;a是左值就调用对应fun函数的左值引用,我们来看运行结果

在这里插入图片描述
结果未达到我们的预期,是右值的没有匹配到对应的右值函数,这是因为,右值引用的属性还是左值,所以就会出现全是左值的情况,为了解决以上这种问题,C++11库中实现了一个功能“完美转发”,forward,该功能就是保持原来的属性,实现是左值引用的就保持左值属性,右值引用的就保持右值属性,该接口的本质实际上还是类型强转,使用方法如下:

template<class T>
void Func(T&& t)
{//将原代码改成这样即可fun(std::forward<T>(t));
}

在这里插入图片描述

1.3 lambda表达式语法

1.3.1 定义

lambda表达式本质是一个匿名函数对象,跟普通函数不同的是它可以定义在函数内部。lambda表达式对于语法使用层面而言没有类型,所以一般是用auto或者函数模板参数定义的对象去接收lambda对象

lambda表达式的格式:capture-list->return type{function body}

  • capture-list:捕捉列表,该列表总是出现在lambda函数的开始,编译器根据捕捉列表来判断接下来的代码是否为lambda函数。捕捉列表能够捕捉上下文中的变量lambda函数使用,捕捉列表可以通过传值和传引用捕捉,捕捉列表为空也不能省略
  • parmeters:参数列表。不传参时可以连同()一同省略
  • return type:返回类型,用于追踪返回类型形式声明函数的返回值类型,没有返回值时,可以省略。一般返回值类型明确的情况下,也可以省略,由编译器对返回值类型进行推导。
  • function body:函数体

用法示例:

int main()
{auto add = [](int x, int y)->int {return x + y; };std::cout << add(1, 2) << std::endl;auto func = [] //参数列表和返回值省略{std::cout << "hello world" << std::endl;};return 0;
}

1.3.2 lambda的使用场景

在学习lambda之前,可调用对象只有函数指针和仿函数对象,但函数指针的类型定义起来比较麻烦,仿函数要定义一个类,相对来说也会比较麻烦。使用lambda去定义可调用对象,既简单又方便

看下面代码:

#include <vector>
#include <iostream>
#include <algorithm>
struct goods
{std::string _name; //商品名称double _price; //价格int _evaluate; //评估goods(const char* name,double price,int evaluate):_name(name),_price(price),_evaluate(evaluate){ }
};
struct comparePriceLess
{bool operator()(const goods& lg, const goods& rg){return lg._price < rg._price;}
};
struct comparePriceGreater
{bool operator()(const goods& lg, const goods& rg){return lg._price > rg._price;}
};
int main()
{std::vector<goods> list = { {"苹果",1.2,2},{"香蕉",1.5,3},{"葡萄",2.1,5} };//对商品按价格进行排序std::sort(list.begin(), list.end(), comparePriceLess());std::sort(list.begin(), list.end(), comparePriceGreater());return  0;
}

代码中可以看到,通过实现仿函数对象或函数指针来支持不同项的比较,相对来说还是比较麻烦的,要实现好多个我们所需要的仿函数,那么lambda就很好的解决了这一点

代码如下:

#include <vector>
#include <iostream>
#include <algorithm>
struct goods
{std::string _name; //商品名称double _price; //价格int _evaluate; //评估goods(const char* name,double price,int evaluate):_name(name),_price(price),_evaluate(evaluate){ }
};
int main()
{std::vector<goods> list = { {"苹果",1.2,2},{"香蕉",1.5,3},{"葡萄",2.1,5} };auto priceLess = [](const goods& lg, const goods& rg){return lg._price < rg._price; };//对价格进行排序std::sort(list.begin(), list.end(), priceLess);std::sort(list.begin(), list.end(), [](const goods& lg, const goods& rg){return lg._price > rg._price; });//对评估进行排序std::sort(list.begin(), list.end(), [](const goods& lg, const goods& rg){return lg._evaluate < rg._evaluate;});std::sort(list.begin(), list.end(), [](const goods& lg, const goods& rg) {return lg._evaluate > rg._evaluate;});return 0;
}

lambda本质上还是一个仿函数,该表达式其实就相当于一个“语法糖”

1.3.3 捕捉列表

lambda表达式中默认只能使用lambda函数体和参数中的变量,如果想使用外层作用域中的变量就需要进行捕捉

  • 捕捉的第一种方法:在捕捉列列表中显示的传值捕捉和引用捕捉捕捉的多个变量用逗号分割

伪代码例:

int a = 1,b = 2,c = 3;
auto add = [a,b,&c]{return a + b + c;}; 
//捕捉列表表示:a和b是值捕捉,&c是引用捕捉

注意:传引用捕捉的变量,若在lambda中被修改了,外部域的也会跟着修改

  • 捕捉的第二种方法:隐式捕捉,[=],表示隐式捕捉;[&],表示隐式引用捕捉,这样我们在lambda表达式中用了哪些变量,编译器就会自动捕捉

伪代码例:

int a = 1,b = 2,c = 3;
auto add = [=]{return a + b + c;}; 
auto func=[&]{a++;b--; return a+b+c;};

注意:lambda表达式中用了哪些变量,编译器就会去自动捕捉哪些变量,没有用到的就不会去捕捉

  • 捕捉的第三种方法:混合使用隐式捕捉和显示捕捉

伪代码例:

int a = 1,b = 2,c = 3,d = 4;
auto function1 = [=,&d]{d++;return a + d;}; //表示其他变量隐式捕捉,d显示引用捕捉
auto function2 = [&,a,b]{c++;return a + b;}; // 表示其他变量隐式引用捕捉,a和b是显示值捕捉

注意:当混合使用时,第一个元素必须是=或者&,并且第一个元素为&混合捕捉时,后面的捕捉必须为值捕捉,同理第一个元素为=混合捕捉时,后面的捕捉必须为引用捕捉

注意:局部的静态变量和全局变量不能捕捉,也不需要捕捉,直接就可以使用

1.3.4 mutable语法

lambda表达式中,传值捕捉本质上是一种拷贝,并且被const修饰所以不能被修改,但可以用mutable关键字来使值捕捉的变量在lambda表达式中被修改,但被修改的变量不会影响外部域的变量,因为它是一种拷贝

代码例:

int main()
{int a = 1, b = 2, c = 3;auto func = [=]()mutable {a++; b++; return a+b+c;};std::cout << func() << std::endl;std::cout << "a:" << a << " " << "b:" << b << " " << "c:" << c << std::endl;return 0;
}

在这里插入图片描述
可以看到外部域的变量并没有被修改

1.3.5 lambda的原理

lambda底层是仿函数对象,当写了一个lambda以后,编译器会自动生成一个对应的仿函数的类。仿函数的类型名是编译器按一定规则生成的,保证不同的lambda生成的类型名不同,lambda参数/返回类型/函数体就是仿函数operator的参数/返回类型/函数体,它的捕捉列表本质是生成的仿函数类的成员变量,也就是说捕捉列表的变量都是lambda类构造函数的实参,若是隐式捕捉,编译器要看使用哪些就传哪些变量.

相关文章:

C++11-(2)

文章目录 &#xff08;一&#xff09;C11新增功能1.1 引用折叠1.1.1 在模板中使用引用折叠的场景1.1.2 引用折叠是如何实现的 1.2 完美转发1.3 lambda表达式语法1.3.1 定义1.3.2 lambda的使用场景1.3.3 捕捉列表1.3.4 mutable语法1.3.5 lambda的原理 &#xff08;一&#xff09…...

LeetCode算 法 实 战 - - - 双 指 针 与 移 除 元 素、快 慢 指 针 与 删 除 有 序 数 组 中 的 重 复 项

LeetCode算 法 实 战 - - - 双 指 针 与 移 除 元 素、快 慢 指 针 与 删 除 有 序 数 组 中 的 重 复 项 第 一 题 - - - 移 除 元 素方 法 一 - - - 双 重 循 环方 法 二 - - - 双 指 针方 法 三 - - - 相 向 双 指 针&#xff08;面 对 面 移 动&#xff09; 第 二 题 - - -…...

QT6 源(106):阅读与注释重要的基类控件 QWidget,这是其精简版,完整注释版为篇 37

&#xff08;1&#xff09;原篇幅 37 为最开始整理&#xff0c;整理的不是太完善。重点不突出。故重新整理&#xff0c;但删除了大量的注释&#xff0c;重在突出本 QWidget类的内部逻辑&#xff0c;更易观察其包含了哪些内容。至于不理解的成员函数与属性&#xff0c;内容已不太…...

【Bluedroid】蓝牙HID DEVICE错误报告处理全流程源码解析

本文基于Android蓝牙协议栈代码&#xff0c;深入解析HID设备在接收非法指令&#xff08;如无效的SET_REPORT&#xff09;时的错误处理全流程&#xff0c;涵盖错误映射、协议封装、传输控制三大核心模块。重点剖析以下机制&#xff1a; HID协议规范错误码的动态转换策略 控制通…...

Day29 类的装饰器

类也有修饰器&#xff0c;他的逻辑类似&#xff1a;接收一个类&#xff0c;返回一个修改后的类。例如 添加新的方法或属性&#xff08;如示例中的 log 方法&#xff09;。修改原有方法&#xff08;如替换 init 方法&#xff0c;添加日志&#xff09;。甚至可以返回一个全新的类…...

学习黑客Active Directory 入门指南(二)

Active Directory 入门指南&#xff08;二&#xff09;&#xff1a;深入逻辑结构与物理组件 &#x1f333;&#x1f3e2; 大家好&#xff01;欢迎回到 “Active Directory 入门指南” 系列的第二篇。在上一篇中&#xff0c;我们初步认识了Active Directory&#xff0c;了解了其…...

为什么el-select组件在下拉选择后无法赋值

为什么el-select组件在下拉选择后无法赋值 https://blog.csdn.net/ZHENGCHUNJUN/article/details/127325558 这个链接解决了大模型无法解决的问题 大模型能够写基础且高级一些的代码&#xff0c;但是遇到再深入一些的问题&#xff0c;还是得问百度。对于我这种小白来说问题原因…...

FreeRTOS的学习记录(临界区保护,调度器挂起与恢复)

临界区 在 FreeRTOS 中&#xff0c;临界区&#xff08;Critical Section&#xff09; 是指程序中一段必须以原子方式执行的代码区域&#xff0c;在此区域内不允许发生任务切换或中断干扰&#xff0c;以保护共享资源或执行关键操作。FreeRTOS 提供了多种机制来实现临界区&#…...

给个人程序加上MCP翅膀

背景 最近MCP这个词真是到处都是&#xff0c;看起来特别高大上。我平时没事的时候也一直在关注这方面的技术&#xff0c;知道它是怎么一回事&#xff0c;也懂该怎么去实现。但可惜一直抽不出时间来自己动手搞一个MCP服务。网上关于MCP的教程一搜一大把&#xff0c;但基本上都是…...

2023年河南CCPC(ABCEFHK)

文章目录 2023河南CCPCA. 小水獭游河南(字符串)B. Art for Rest(数组切割)C. Toxel与随机数生成器(水)E. 矩阵游戏&#xff08;dp&#xff09;F. Art for Last(区间最小差分)H. Travel Begins(数学思维)K. 排列与质数&#xff08;规律&#xff09;总结 2023河南CCPC A. 小水獭…...

【 Redis | 实战篇 秒杀优化 】

目录 前言&#xff1a; 1.分布式锁 1.1.分布式锁的原理与方案 1.2.Redis的String结构实现分布式锁 1.3.锁误删问题 1.4.锁的原子性操作问题 1.5.Lua脚本解决原子性问题 1.6.基于String实现分布式锁存在的问题 1.7.Redisson分布式锁 2.秒杀优化 3.秒杀的异步优化 3.1…...

【Spring】核心机制:IOC与DI深度解析

目录 1.前言 2.正文 2.1三层架构 2.2Spring核心思想&#xff08;IOC与AOP&#xff09; 2.3两类注解&#xff1a;组件标识与配置 2.3.1五大类注解 2.3.1.1Controller 2.3.1.2Service 2.3.1.3Repository 2.3.1.4Configuration 2.3.1.5Component 2.3.2方法注解&#x…...

1-机器学习的基本概念

文章目录 一、机器学习的步骤Step1 - Function with unknownStep2 - Define Loss from Training DataStep3 - Optimization 二、机器学习的改进Q1 - 线性模型有一些缺点Q2 - 重新诠释机器学习的三步Q3 - 机器学习的扩展Q4 - 过拟合问题&#xff08;Overfitting&#xff09; 一、…...

ARM A64 STR指令

ARM A64 STR指令 1 STR (immediate)1.1 Post-index1.1.1 32-bit variant1.1.2 64-bit variant 1.2 Pre-index1.2.1 32-bit variant1.2.2 64-bit variant 1.3 Unsigned offset1.3.1 32-bit variant1.3.2 64-bit variant 1.4 Assembler symbols 2 STR (register)2.1 32-bit varia…...

虚幻引擎5-Unreal Engine笔记之`GameMode`、`关卡(Level)` 和 `关卡蓝图(Level Blueprint)`的关系

虚幻引擎5-Unreal Engine笔记之GameMode、关卡&#xff08;Level&#xff09; 和 关卡蓝图&#xff08;Level Blueprint&#xff09;的关系 code review! 文章目录 虚幻引擎5-Unreal Engine笔记之GameMode、关卡&#xff08;Level&#xff09; 和 关卡蓝图&#xff08;Level B…...

软件工具:批量图片区域识别+重命名文件的方法,发票识别和区域选择方法参考,基于阿里云实现

基于阿里云的批量图片区域识别与重命名解决方案 图像识别重命名 应用场景 ​​企业档案管理​​&#xff1a;批量处理扫描的合同、文件等图片&#xff0c;根据合同编号、文件标题等关键信息重命名文件​​医疗影像处理​​&#xff1a;识别X光、CT等医学影像中的患者ID、检查日…...

.NET外挂系列:1. harmony 基本原理和骨架分析

一&#xff1a;背景 1. 讲故事 为什么要开这么一个系列&#xff0c;是因为他可以对 .NET SDK 中的方法进行外挂&#xff0c;这种技术对解决程序的一些疑难杂症特别有用&#xff0c;在.NET高级调试 领域下大显神威&#xff0c;在我的训练营里也是花了一些篇幅来说这个&#xf…...

深入理解位图(Bit - set):概念、实现与应用

目录 引言 一、位图概念 &#xff08;一&#xff09;基本原理 &#xff08;二&#xff09;适用场景 二、位图的实现&#xff08;C 代码示例&#xff09; 三、位图应用 1. 快速查找某个数据是否在一个集合中 2. 排序 去重 3. 求两个集合的交集、并集等 4. 操作系…...

React Flow 边事件处理实战:鼠标事件、键盘操作及连接规则设置(附完整代码)

本文为《React Agent&#xff1a;从零开始构建 AI 智能体》专栏系列文章。 专栏地址&#xff1a;https://blog.csdn.net/suiyingy/category_12933485.html。项目地址&#xff1a;https://gitee.com/fgai/react-agent&#xff08;含完整代码示​例与实战源&#xff09;。完整介绍…...

【计算机网络】第一章:计算机网络体系结构

本篇笔记课程来源&#xff1a;王道计算机考研 计算机网络 【计算机网络】第一章&#xff1a;计算机网络体系结构 一、计算机网络的概念1. 理论2. 计算机网络、互连网、互联网的区别 二、计算机网络的组成、功能1. 组成2. 功能 三、交换技术1. 电路交换2. 报文交换3. 分组交换4.…...

实战设计模式之状态模式

概述 作为一种行为设计模式&#xff0c;状态模式允许对象在其内部状态改变时&#xff0c;改变其行为。这种模式通过将状态逻辑从对象中分离出来&#xff0c;并封装到独立的状态类中来实现。每个状态类代表一种特定的状态&#xff0c;拥有自己的一套行为方法。当对象的状态发生变…...

[C++入门]类和对象中(2)日期计算器的实现

目录 一、运算符重载 1、格式 2、简单举例 2、前置&#xff0c;后置 3、日期生成器的实现 1、声明与定义 1、友元函数 2、print函数 3、运算符重载 4、GetMonthDay 5、&#xff0c;-&#xff0c;&#xff0c;-的实现 6、重载流操作符 2、实现 3、定义源码 一、运算…...

数据质量问题的形成与解决

在数字化时代&#xff0c;数据已成为企业和组织发展的核心资产&#xff0c;数据质量的高低直接影响着决策的准确性、业务的高效性以及系统的稳定性。然而&#xff0c;数据质量问题频发&#xff0c;严重阻碍了数据价值的充分发挥。 一、数据质量问题的成因分析 1.信息因素 元数…...

论文阅读(四):Agglomerative Transformer for Human-Object Interaction Detection

论文来源&#xff1a;ICCV&#xff08;2023&#xff09; 项目地址&#xff1a;https://github.com/six6607/AGER.git 1.研究背景 人机交互&#xff08;HOI&#xff09;检测需要同时定位人与物体对并识别其交互关系&#xff0c;核心挑战在于区分相似交互的细微视觉差异&#…...

【机器学习】工具入门:飞牛启动Dify Ollama Deepseek

很久没有更新文章了,最近正好需要研究一些机器学习的东西&#xff0c;打算研究一下 difyOllama 以下是基于FN 的dify本地化部署&#xff0c;当然这也可能是全网唯一的飞牛部署dify手册 部署 官方手册&#xff1a;https://docs.dify.ai/en/getting-started/install-self-hos…...

课外活动:再次理解页面实例化PO对象的魔法方法__getattr__

课外活动&#xff1a;再次理解页面实例化PO对象的魔法方法__getattr__ 一、动态属性访问机制解析 1.1 核心实现原理 class Page:def __getattr__(self, loc):"""魔法方法拦截未定义属性访问"""if loc not in self.locators.keys():raise Exce…...

面试题总结二

1.mybatis三个范式 第一范式&#xff1a;表中字段不能再分&#xff0c;每行数据都是唯一的第二范式&#xff1a;满足第一范式&#xff0c;非主键字段只依赖于主键第三范式&#xff1a;满足第二范式&#xff0c;非主键字段没有传递依赖 2.MySQL数据库引擎有哪些 InnoDB&#…...

代码随想录算法训练营第六十六天| 图论11—卡码网97. 小明逛公园,127. 骑士的攻击

继续补&#xff0c;又是两个新算法&#xff0c;继续进行勉强理解&#xff0c;也是训练营最后一天了&#xff0c;六十多天的刷题告一段落了&#xff01; 97. 小明逛公园 97. 小明逛公园 感觉还是有点难理解原理 Floyd 算法对边的权值正负没有要求&#xff0c;都可以处理。核心…...

编程技能:字符串函数07,strncat

专栏导航 本节文章分别属于《Win32 学习笔记》和《MFC 学习笔记》两个专栏&#xff0c;故划分为两个专栏导航。读者可以自行选择前往哪个专栏。 &#xff08;一&#xff09;WIn32 专栏导航 上一篇&#xff1a;编程技能&#xff1a;字符串函数06&#xff0c;strcat 回到目录…...

[Java实战]Spring Boot整合RabbitMQ:实现异步通信与消息确认机制(二十七)

[Java实战]Spring Boot整合RabbitMQ&#xff1a;实现异步通信与消息确认机制&#xff08;二十七&#xff09; 摘要&#xff1a;本文通过完整案例演示Spring Boot与RabbitMQ的整合过程&#xff0c;深入讲解异步通信原理与消息可靠性保证机制。包含交换机类型选择、消息持久化配…...

数据库中关于查询选课问题的解法

前言 今天上午起来复习了老师上课讲的选课问题。我总结了三个解法以及一点注意事项。 选课问题介绍 简单来说就是查询某某同学没有选或者选了什么课。然后查询出该同学的姓名&#xff0c;学号&#xff0c;课程号&#xff0c;课程名之类的。 sql文件我上传了。大家可以尝试练…...

用 UniApp 开发 TilePuzzle:一个由 CodeBuddy 主动驱动的拼图小游戏

我正在参加CodeBuddy「首席试玩官」内容创作大赛&#xff0c;本文所使用的 CodeBuddy 免费下载链接&#xff1a;腾讯云代码助手 CodeBuddy - AI 时代的智能编程伙伴 起心动念&#xff1a;从一个小游戏想法开始 最近在使用 UniApp 做练手项目的时候&#xff0c;我萌生了一个小小…...

golang 安装gin包、创建路由基本总结

文章目录 一、安装gin包和热加载包二、路由简单场景总结 一、安装gin包和热加载包 首先终端新建一个main.go然后go mod init ‘项目名称’执行以下命令 安装gin包 go get -u github.com/gin-gonic/gin终端安装热加载包 go get github.com/pilu/fresh终端输入fresh 运行 &…...

组态王|组态王中如何添加西门子1200设备

哈喽,你好啊,我是雷工! 最近使用组态王采集设备数据,设备的控制器为西门子的1214CPU, 这里边实施边记录,以下为在组态王中添加西门子1200PLC的笔记。 1、新建 在组态王工程浏览器中选择【设备】→点击【新建】。 2、选择设备 和设备建立通讯要通过对应的设备驱动。 在…...

碎片笔记|PromptStealer复现要点(附Docker简单实用教程)

前言&#xff1a;本篇博客记录PromptStealer复现历程&#xff0c;主要分享环境配置过程中的一些经验。 论文信息&#xff1a;Prompt Stealing Attacks Against Text-to-Image Generation Models. USENIX, 2024. 开源代码&#xff1a;https://github.com/verazuo/prompt-stealin…...

Docker配置SRS服务器 ,ffmpeg使用rtmp协议推流+vlc拉流

目录 演示视频 前期配置 Docker配置 ffmpeg配置 vlc配置 下载并运行 SRS 服务 推拉流流程实现 演示视频 2025-05-18 21-48-01 前期配置 Docker配置 运行 SRS 建议使用 Docker 配置 Docker 请移步&#xff1a; 一篇就够&#xff01;Windows上Docker Desktop安装 汉化完整指…...

c++学习之--- list

目录 ​编辑 一、list的定义: 二、list的模拟实现&#xff1a; 1、list的基本框架&#xff1a; 2、list的普通迭代器&#xff1a; 设计思想&#xff1a; 迭代器的一个特殊需求&#xff08;c 对于重载->的一颗语法糖&#xff09;&#xff1a; 代码实现&#xff1a; 3、cons…...

【C++】set、map 容器的使用

文章目录 1. set 和 multiset 的使用1.1 set类的介绍1.2 set的构造和迭代器1.3 set 的增删查1.4 insert和迭代器调用示例1.5 find和erase使用示例1.6 multiset和set的差异 2. map 和 multimap 的使用2.1 map 类的介绍2.2 pair 类型介绍2.3 map 的构造和迭代器2.4 map 的增删查2…...

实习记录小程序|基于SSM+Vue的实习记录小程序设计与实现(源码+数据库+文档)

实习记录小程序 目录 基于SSM的习记录小程序设计与实现 一、前言 二、系统设计 三、系统功能设计 1、小程序端&#xff1a; 2、后台 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 博主介绍&#xff1a;✌️大厂码…...

Git从入门到精通

Git 是什么 Git 是一个分布式版本控制系统&#xff0c;主要用于跟踪和管理文件&#xff08;尤其是代码&#xff09;的变更。 Git的下载与安装 进入git官网下载界面,选择Windows系统。 点击选择Git for Windows/x64 Setup,进行安装。 注意: Git GUI 是Git提供的一个图形界面工…...

Binary Prediction with a Rainfall Dataset-(回归+特征工程+xgb)

Binary Prediction with a Rainfall Dataset 题意&#xff1a; 给你每天的天气信息&#xff0c;让你预测降雨量。 数据处理&#xff1a; 1.根据特征值构造天气降雨量的新特征值 2.根据时间构造月和季节特征 3.处理缺失值 建立模型&#xff1a; 1.建立lightgbm模型 2.建立…...

【C++】unordered_map与set的模拟实现

unordered系列map和set&#xff0c;与普通区别 用法几乎相同&#xff0c;键值唯一&#xff0c;区别unordered系列迭代器是单向的并且遍历出来不是有序的。unordered系列在数据规模大且无序的情况下性能更优 底层实现&#xff1a; map 和 set &#xff1a;基于平衡二叉树&…...

老旧设备升级利器:Modbus TCP转 Profinet让能效监控更智能

在工业自动化领域&#xff0c;ModbusTCP和Profinet是两种常见的通讯协议。Profinet是西门子公司推出的基于以太网的实时工业以太网标准&#xff0c;而Modbus则是由施耐德电气提出的全球首个真正开放的、应用于电子控制器上的现场总线协议。这两种协议各有各的优点&#xff0c;但…...

编译原理--期末复习

本文是我学习以下博主视频所作的笔记&#xff0c;写的不够清晰&#xff0c;建议大家直接去看这些博主的视频&#xff0c;他/她们讲得非常好&#xff1a; 基础知识概念&#xff1a; 1.【【编译原理】期末复习 零基础自学】&#xff0c;资料 2.【编译原理—混子速成期末保过】&…...

软件工程各种图总结

目录 1.数据流图 2.N-S盒图 3.程序流程图 4.UML图 UML用例图 UML状态图 UML时序图 5.E-R图 首先要先了解整个软件生命周期&#xff1a; 通常包含以下五个阶段&#xff1a;需求分析-》设计-》编码 -》测试-》运行和维护。 软件工程中应用到的图全部有&#xff1a;系统…...

Go 与 Gin 搭建简易 Postman:实现基础 HTTP 拨测的详细指南

Go 与 Gin 搭建简易 Postman&#xff1a;实现基础 HTTP 拨测的详细指南 文章目录 Go 与 Gin 搭建简易 Postman&#xff1a;实现基础 HTTP 拨测的详细指南项目简介代码结构各部分代码功能说明&#xff1a; 代码实现&#xff1a;main.go代码解释 handlers/probe.go代码解释 probe…...

层次原理图

层次原理图简介 层次原理图&#xff08;Hierarchical Schematic&#xff09;是一种常用于电子工程与系统设计的可视化工具&#xff0c;通过分层结构将复杂系统分解为多个可管理的子模块。它如同“设计蓝图”&#xff0c;以树状结构呈现整体与局部的关系&#xff1a;顶层展现系…...

嵌入式硬件篇---拓展板

文章目录 前言 前言 本文简单介绍了拓展板的原理以及使用。...

Redis的主从架构

主从模式 全量同步 首先主从同步过程第一步 会先比较replication id 判断是否是第一次同步假设为第一次同步 那么就会 启动bgsave异步生成RDB 同时fork子进程记录生成期间的新数据发送RDB给从节点 清空本地数据写入RDB 增量同步 对比ReplicationID不同因此选择增量同步在Rep…...

IIS入门指南:原理、部署与实战

引言&#xff1a;Web服务的基石 在Windows Server机房中&#xff0c;超过35%的企业级网站运行在IIS&#xff08;Internet Information Services&#xff09;之上。作为微软生态的核心Web服务器&#xff0c;IIS不仅支撑着ASP.NET应用的运行&#xff0c;更是Windows Server系统管…...