C++ STL map和set的使用
序列式容器和关联式容器
想必大家已经接触过一些容器如:list,vector,deque,array,forward_list,string等,这些容器统称为系列容器。因为逻辑结构为线性的,两个位置的存储的值一般是没有固定关系的,比如交换一下并不会破坏它的结构特点。序列式容器一般是通过来顺序保存和访问的
关联式容器也是用来存储数据的,与序列式容器不同,关联式容器逻辑结构通常是非线性的,两个位置之间通常有紧密的联系,如果进行位置交换,那么就会破坏容器的结构。关联式容器中的元素一般是按关键字来保存和访问的。关联式容器有map/set系列和unordered_map/unordered_set系列。
本博客主要讲map和set系列容器的使用
map和set底层都是由红黑树来实现的,本质是一颗平衡二叉树,因此效率是极高的。
其中set是Key结构,map是Key-Value结构
pair类的介绍
在正式了解map、set前,我们要知道pair这个类型。
pair在关联式容器里面的使用是很频繁的,需要大家知道它是什么,这里直接给出它的底层代码:
typedef pair<const Key, T> value_type;
template <class T1, class T2>
struct pair
{typedef T1 first_type;typedef T2 second_type;T1 first;T2 second;pair(): first(T1()), second(T2()){}pair(const T1& a, const T2& b): first(a), second(b){}template<class U, class V>pair (const pair<U,V>& pr): first(pr.first), second(pr.second){}};template <class T1,class T2>inline pair<T1,T2> make_pair (T1 x, T2 y){return ( pair<T1,T2>(x,y) );
}
我们可以看出,它就是一个结构体,存的两个数据。因为我们写代码的过程有很多数据有对应关系,因此pair的使用非常频繁。它可以免去我们自己构造一个相同类的麻烦。
make_pair(1, 2);
pair<int, int>(1, 2);
make_pair和下面的使用是一样的,但是make_pair可以推到出类型。下面的需要手动输入类型。
set的使用
首先set是一个存储K结构,存储的数据不能重复的容器。
下面是相关的函数
begin | 返回正向迭代器的开头 |
end | 返回正向迭代器的结尾 |
rbegin | 返回反向迭代器的开头 |
rend | 返回反向迭代器的结尾 |
cbegin | 返回正向常迭代器的开头 |
cend | 返回正向常迭代器的结尾 |
crbegin | 返回反向常迭代器的开头 |
crend | 返回反向常迭代器的结尾 |
empty | 判断容器是否为空 |
size | 返回容器的数据个数 |
max_size | 返回容器存储的最大值,一般系统会检测计算机内存做出合理的返回值 |
insert | 插入一个值 |
erase | 删除一个值 |
swap | 交换两个set的数据 |
clear | 清除一个set容器的数据 |
emplace | 插入一个数据,和insert的效果等效 |
key_comp | 返回一个比较对象 |
value_comp | 返回一个比较对象 |
find | 对数据进行查找 |
count | 查找某个值的数量 |
lower_bund | 返回一个大于等于某个值的迭代器 |
upper_bound | 返回一个大于某个值的迭代器 |
equal_range | 返回大于等于某个值和大于某个值两个的迭代器 |
首先在了解上面的函数前,我们要了解set的构造函数、
构造函数
这里我只说一些常用的构造方式:
默认构造
set<int>con;
这种方式构造出来的set容器为空。可以进行后续的插入
拷贝构造
set<int>con;
set<int>con_(con);
set<int>con__ = con;
用其他的set值来构造一个新的set
初始化生定向列表构造
set<int>con{ 1,2,3,4,5,6,34,2 };
set<int>con_({ 1,3,4,5,6 });
set<int>con__ = { 1234,325,2 };
这种构造输入十分方便
迭代器构造
vector<int>vec{ 1,2,34,5,2 };
set<int>(vec.begin(), vec.end());
int arr[] = { 1,2,3,4 };
set<int>(arr, arr + 3);
迭代器构造能够夸容器,进行数据的流通。
同时我们在构造的时候可以传函数指针或者仿函数来改变set的存储形式
bool compare(int x, int y) {return x > y;
}struct compare_ {bool operator()(const int&x,const int& y)const {return x > y;}
};
int main(){bool(*pare)(int, int) = compare;compare_ pare_;set<int, bool(*)(int, int)>con({ 2432423,21,23,4,5,345,34,5 },pare);set<int,compare_>con_({ 2432423,21,23,4,5,345,34,5 });set<int, greater<int>>con__({ 2432423,21,23,4,5,345,34,5 });for (auto& num : con)cout << num<<" ";cout << endl;for (auto& num : con_)cout << num<<" ";cout << endl;for (auto& num : con__)cout << num << " ";return 0;
}
//打印结果
//2432423 345 34 23 21 5 4
//2432423 345 34 23 21 5 4
//2432423 345 34 23 21 5 4
通过比较的改变将升序变为降序。
这几个构造基本上可以满足所有的构造需求了。
下面的构造是优化效率
右值引用构造
这个构造是将右值构造直接夺取其值来进行构造,减少拷贝,加快了构造的速度。
一般大家传常量值机会出发它的构造
set<int>contain(set<int>{1, 3});
成员函数
下面开始看成员函数的使用
迭代器相关的函数
如果还不知道迭代器是什么或者迭代器还不会使用的,可以看看这篇博客:迭代器的使用
看完之后对于迭代器的几个函数应该是懂的,这里就不做过多的讲解了。
size empty
这里size和empty函数也不做讲解,就是返回容器的数据量和判空。
max_size:
这个函数就是在我们插入比较多的数据时,我们要判断一下这些数据能否一下存的完。
int arr[10000] = { 123,21,321,3,12,3,21,4,3243,543,6,34,43,4124/*...........*/ };
int len = sizeof(arr) / sizeof(int);
set<int>con;
if (len < con.max_size()) {for (int x = 0; x < len; ++x)con.insert(arr[x]);
}
else {cout << "存不下" << endl;assert(false);
}
insert
insert虽然大家知道是干什么的,但是它的重载形式是有很多的,还有返回值是怎么返回的都需要知道
//1
pair<iterator,bool> insert (const value_type& val);
//2
pair<iterator,bool> insert (value_type&& val);
//3
iterator insert (const_iterator position, const value_type& val);
//4
iterator insert (const_iterator position, value_type&& val);
//5
template <class InputIterator>
void insert (InputIterator first, InputIterator last);
//6
void insert (initializer_list<value_type> il);
第一个和第二个的输入我就不多说了,这里说一下它的返回值,上面我讲解了pair的使用,那么这里就返回了两个值,first是成功插入后的这个值的迭代器或者失败后已经有的值的迭代器,second是判断这个值是否插入成功。
例如:
set<int>con{ 1,2};
pair<set<int>::iterator, bool>p = con.insert(1);
if (p.second) {cout << "插入成功" << endl;
}
else cout << "插入失败";
//输出插入失败
第三个和第四个是在对应迭代器的后面插入一个值,返回这个插入的迭代器,如果set里面已经有了这个值,那么就会返回这个值的迭代器。
int arr[10000] = { 123,21,321,3,12,3,21,4,3243,543,6,34,43,4124/*...........*/ };
int len = sizeof(arr) / sizeof(int);
set<int>con{ 1,2};
set<int>::iterator it = con.insert(con.begin(), 2);
for (auto num:con)cout << num;
// 1 2
第四个就是插入一个迭代器区间的值,相当于进行了n次单个迭代器的插入。
第五个就是插入一段初始化设定项列表里面的数据。
第四个和第五个因为是多插入,不好返回各个插入情况的布尔值。所以是void。
erase
//(1)
iterator erase (const_iterator position);
//(2)
size_type erase (const value_type& val);
//(3)
iterator erase (const_iterator first, const_iterator last);
对于用值来查找
就返回成功删除值的个数,这里因为值不能重复,因此只会返回0或1
对于用迭代器或则迭代器区间来删除,会返回这个值或者迭代器最后一次删除的值的下一个迭代器。区间迭代器删除时迭代器是左开右闭的,考虑删除begin(),end()区间就理解什么了。
那么就有这种写法:可以删除里面的偶数
set<int>con{ 1,2,3,4,5,6 };
for (auto it = con.begin(); it != con.end();) {if ((*it) % 2 == 0)it = con.erase(it);else ++it;
}
for (auto& num : con)cout << num << " ";
//1 3 5
我们不能一直it++,因为erase后it会直接跳到下一个值上。
swap
交换两个map的值
是否是以下面的代码交换的呢?
template<class K>
void swap(set<K>& x, set<K>& y) {set<K>temp = x;x = y;y = temp;
}
觉得是就错了,这种会有大量的拷贝,效率急转直下。
只要把里面的_root的指针交换一下就行了,数据就交换了。
clear
这个不多说,就是将数据清完
emplace
这个用到了右值引用移动构造,在插入右值的时候构造速度会快一些。效果和insert一样。
key_comp
会返回一个key_compare类型,它的效果类似于operator<重载,用的不多,看下面代码演示就行了
// set::key_comp
#include <iostream>
#include <set>int main ()
{std::set<int> myset;int highest;std::set<int>::key_compare mycomp = myset.key_comp();for (int i=0; i<=5; i++) myset.insert(i);std::cout << "myset contains:";highest=*myset.rbegin();std::set<int>::iterator it=myset.begin();do {std::cout << ' ' << *it;} while ( mycomp(*(++it),highest) );std::cout << '\n';return 0;
}
//myset contains: 0 1 2 3 4
value_comp
从k的比较换成了value的比较,这里的value和key是相同的,因此这两个函数相同
find
查找一个值并返回它的迭代器
如果找不到就会返回end()迭代器。
count
查找某个值的个数,因为容器不允许重复数据,因此返回值只有0或者1。
lower_bound
返回第一个大于等于某个值的迭代器
因为set的去重性,最后要么返回等于这个值的迭代器,要么返回第一个大于这个值的迭代器。
upper_bound
返回第一个大于某个值的迭代器
这个比lower_bound稍微窄一点,当没有要查找的那个值时lower_bound的效果等于upper_bound效果。
例如要删除[10,60]的数据:
set<int>con{ 0,10,20,30,40,50,60,70};
con.erase(con.lower_bound(10), con.upper_bound(60));
for (auto num : con)cout << num << " ";
//0 70
equal_range
作用是找到等于某个值的区间,返回装有两个迭代器的pair类,范围是做开右闭。
那么就和上面的lower_bound和upper_bound差不多了,等价返回make_pair(lower_bound,upper_bound)。但是估计这个函数的效率更高,因为两次_bound都是从开始往后找,但是equal_range可以在lower_bound的基础上找upper_bound的迭代器。
multiset的使用
成员函数
multiset和set的差异就multiset支持冗余值。其它是一模一样的。那么我就只说函数里面不同的地方。
erase
删除的时候,会把所有等于它的值删除,并不是只删一个。
find
他是寻找中序的第一个目标值
count
因为有冗余值,因此范围可以是[0,max_size]
其它就是一样的,这里就不重复说了
map的使用
map就是K-V的结构, 通过K来寻找,同时可以找到对应的映射值V。其中K是不能修改的,不然破坏了结构,V可以修改。
增删查改和set的不同
这里我不具体一个一个讲,只讲和set不同的点。不同点只有一个,插入删除都是直接作用pair整体,插入用pair,删除就删除K-V整体。
value_comp和key_comp
在set里面两个函数是一样的,这里稍微不一样,一个是比较value,一个是比较key。就这里不同
operator[]
这个是非常重要的修改接口,不仅仅支持修改,还支持插入数据和查找数据,所以他是一个多功能复合接口
我们来看它底层是怎么实现的,首先我们复习一下insert的插入方法
insert插入一个pair<key, T>对象
1、如果key已经在map中,插入失败,则返回一个pair<iterator,bool>对象,返回pair对象
first是key所在结点的迭代器,second是false
2、如果key不在在map中,插入成功,则返回一个pair<iterator,bool>对象,返回pair对象
first是新插入key所在结点的迭代器,second是true
也就是说无论插入成功还是失败,返回pair<iterator,bool>对象的first都会指向key所在的迭
代器
那么也就意味着insert插入失败时充当了查找的功能,正是因为这一点,insert可以用来实现
operator[]
mapped_type& operator[] (const key_type& k)
{
// 1、如果k不在map中,insert会插入k和mapped_type默认值,同时[]返回结点中存储
//mapped_type值的引用,那么我们可以通过引用修改返映射值。所以[]具备了插入+修改功能
// 2、如果k在map中,insert会插入失败,但是insert返回pair对象的first是指向key结点的
//迭代器,返回值同时[]返回结点中存储mapped_type值的引用,所以[]具备了查找+修改的功能
pair<iterator, bool> ret = insert({ k, mapped_type() });
iterator it = ret.first;
return it->second;
}
也可以用一行代码搞定
mapped_type& operator[] (const key_type& k){return (*con.insert(k).first).second;
}
它有一点要注意,就是访问过的一定会插入到列表,做查找的话要考虑是否要让它插入进来,否则就用count查找,或者find查找。
multimap和map的差异
multimap和map的使用基本完全类似,主要区别点在于multimap支持关键值key冗余,那么
insert/find/count/erase都围绕着支持关键值key冗余有所差异,这里跟set和multiset完全一样,比如find时,有多个key,返回中序第一个。其次就是multimap不支持[],因为支持key冗余,[]就只能支持插入了,不能支持修改。
相关文章:
C++ STL map和set的使用
序列式容器和关联式容器 想必大家已经接触过一些容器如:list,vector,deque,array,forward_list,string等,这些容器统称为系列容器。因为逻辑结构为线性的,两个位置的存储的值一般是…...
VisionPro软件Image Stitch拼接算法
2D图像拼接的3种情景 1.一只相机取像位置固定,或者多只相机固定位置拍图,硬拷贝拼图,采用CopyRegion工具实现 2.一只或多只相机在多个位置拍照,相机视野互相重叠,基于Patmax特征定位后,无缝 拼图ÿ…...
缓存-Redis-缓存更新策略-主动更新策略-Cache Aside Pattern(全面 易理解)
**Cache-Aside Pattern(旁路缓存模式)**是一种广泛应用于缓存管理的设计模式,尤其在使用 Redis 作为缓存层时尤为常见。该模式通过在应用程序与缓存之间引入一个旁路,确保数据的一致性和高效性。本文将在之前讨论的 Redis 主动更新…...
Linux(Centos 7.6)命令详解:cd
1.命令作用 改变当前工作目录(change directory) 2.命令语法 Usage: cd [-L|[-P [-e]]] [dir] 3.参数详解 -L,当目标路径是符号链接时,强制使用符号链接,这是一个默认选项。-P,使用物理路径代替符号链接。-e࿰…...
oracle位运算、左移右移、标签算法等
文章目录 位运算基础与或非同或同或应用场景 异或异或应用场景 什么是真值表 oracle基础函数创建bitor(按位或)函数bitnot(按位非)函数bitxor(按位异或)函数左移函数BITSHIFT()函数(实测不可用,废弃掉该方案)右移函数(略,有此场景吗?) 实际应用资质字典…...
预训练语言模型——BERT
1.预训练思想 有了预训练就相当于模型在培养大学生做任务,不然模型初始化再做任务就像培养小学生 当前数据层面的瓶颈是能用于预训练的语料快被用完了 现在有一个重要方向是让机器自己来生成数据并做微调 1.1 预训练(Pre - training)vs. 传…...
基于Thinkphp6+uniapp的陪玩陪聊软件开发方案分析
使用uni-app框架进行前端开发。uni-app是一个使用Vue.js开发所有前端应用的框架,支持一次编写,多端发布,包括APP、小程序、H5等。 使用Thinkphp6框架进行后端开发。Thinkphp6是一个轻量级、高性能、面向对象的PHP开发框架,具有易…...
C++异常处理
C异常处理 C中的异常处理机制是通过try、throw和catch三个关键字来实现的,主要用于捕获和处理程序执行过程中可能出现的错误或异常情况,从而提高程序的健壮性和可维护性。 基本概念 try块:用于定义一个可能抛出异常的代码块。在这个代码块…...
UVM: TLM机制
topic overview 不建议的方法:假如没有TLM TLM TLM 1.0 整个TLM机制下,底层逻辑离不开动作发起者和被动接受者这个底层的模型基础,但实际上,在验证环境中,任何一个组件,都有可能成为动作的发起者࿰…...
基于机器学习的故障诊断(入门向)
一、原始信号的特征提取 1.EMD经验模态分解的作用 信号分析:EMD可以将信号分解为多个IMFs,每个IMF代表信号中的一个特定频率和幅度调制的成分。这使得EMD能够提供对信号的时频特征进行分析的能力(特征提取用到的)。信号去噪&…...
Linux 磁盘管理命令:使用xfs 管理命令
文章目录 Linux磁盘管理命令使用xfs 管理命令1.命令说明2.建立 XFS 文件系统4.调整 XFS 文件系统各项参数5.在线调整 XFS 文件系统的大小6.暂停和恢复 XFS 文件系统7.尝试修复受损的 XFS 文件系统8.备份和恢…...
《Spring Framework实战》8:4.1.3.Bean 概述
欢迎观看《Spring Framework实战》视频教程 Spring IoC 容器管理一个或多个 bean。这些 bean 是使用 您提供给容器的配置元数据(例如,以 XML <bean/>定义的形式)。 在容器本身中,这些 bean 定义表示为BeanDefinition对象&a…...
Spring Boot教程之五十二:CrudRepository 和 JpaRepository 之间的区别
Spring Boot – CrudRepository 和 JpaRepository 之间的区别 Spring Boot建立在 Spring 之上,包含 Spring 的所有功能。由于其快速的生产就绪环境,使开发人员能够直接专注于逻辑,而不必费力配置和设置,因此如今它正成为开发人员…...
MyBatis面试-1
1、什么是MyBatis? MyBatis是一个半ORM框架(对象关系映射)。---》Hibernate全ORM框架 ---》基于JDBC封装的框架 专注于SQL语句,不用关心JDBC操作的其他流程 2、MyBatis有什么优点 基于SQL语句的编程,相对来说会更加的灵活和JDBC相比&#…...
GDPU Android移动应用 重点习题集
目录 程序填空 ppt摘选 题目摘选 “就这两页ppt,你还背不了吗” “。。。” 打开ppt后 “Sorry咯,还真背不了😜” 程序填空 网上摘选的大题也挺合适的,太难的帮大家过滤掉了,大家可以看一下。 ✨SharedPrefere…...
软件开发为什么要用CI/CD方法
现代化业务离不开应用。事实上,62% 的企业认为,应用对其业务至关重要,还有 36% 的企业认为,通过应用提升了竞争优势2。快速可靠的应用开发是在数字世界取得成功的关键。持续集成/持续部署(CI/ CD)方法可帮助…...
湘潭大学人机交互复习
老师没给题型也没划重点,随便看看复习了 什么是人机交互 人机交互(Human-Computer Interaction,HCI)是关于设计、评价和实现供人们使用的交互式计算机系统,并围绕相关的主要现象进行研究的学科。 人机交互研究内容 …...
Java高频面试之SE-10
hello啊,各位观众姥爷们!!!本牛马baby今天又来了!哈哈哈哈哈嗝🐶 equals和 的区别? 在 Java 中,equals() 方法和 运算符都是用于比较两个对象之间的相等性,但它们的工…...
Java 注解详解:RetentionPolicy 与 ElementType
文章目录 1. RetentionPolicy:注解的生命周期RetentionPolicy 的详细说明SOURCE 示例CLASS 示例RUNTIME 示例 2. ElementType:注解的应用范围ElementType 的详细说明ElementType 示例用于类用于方法用于局部变量 3. RetentionPolicy 与 ElementType 的结…...
javafx 将项目打包为 Windows 的可执行文件exe
要将 JavaFX 项目打包为 .exe 文件,你可以使用一些工具将你的应用程序封装为 Windows 可执行文件。以下是两种常用的方法: 方法 1:使用 jpackage(适用于 JDK 14 及更高版本) jpackage 是 JDK 内置的工具,…...
使用Chrome谷歌浏览器中内置翻译功能
谷歌Chrome浏览器作为全球最受欢迎的网络浏览器之一,提供了强大且便捷的内置翻译功能。这一功能帮助用户轻松跨越语言障碍,浏览试听包括音乐视频直播等网页内容了。 一、启用Chrome内置翻译功能 1、打开谷歌Chrome浏览器:确保你已经安装了最…...
Clojure语言的数据库编程
Clojure语言的数据库编程 引言 在当今社会,数据的处理和管理已经成为一个不可或缺的部分。无论是互联网应用、企业系统还是移动应用,都需要与数据库进行频繁的交互。因此,选择一种合适的编程语言和相应的库来进行数据库编程显得尤为重要。C…...
从零开始:使用VSCode搭建Python数据科学开发环境
引言 在数据科学领域,一个高效、稳定的开发环境是成功的关键。本文将详细介绍如何使用Visual Studio Code搭建一个完整的Python数据科学开发环境。通过本指南,您将学会: 安装和配置VSCode,包括基本设置和快捷键配置设置Python开…...
docker minio镜像arm64架构
minio版本为RELEASE.2021-09-03T03-56-13Z 原项目信创改造,服务器资源改为了arm64架构,统信uos docker镜像库内没有对应的minio镜像,当前镜像为拉取源码后,自编译打包镜像,亲测可用。 使用方式 将tar包导入到服务器…...
arcgisPro加载CGCS2000天地图后,如何转成米单位
1、导入加载的天地图影像服务,一开始是经纬度显示的。 2、右键地图,选择需要调整的投影坐标,这里选择坐标如下: 3、点击确定后,就可以调整成米单位的了。 4、切换后结果如下: 如有需要,可调整成…...
MySQL Binlog 监听方案
如果 EmbeddedEngine 类在 debezium-connector-mysql 中不可用,原因是 Debezium 的新版本移除了 EmbeddedEngine。这是因为 Debezium 的架构变更,它现在鼓励使用 Kafka Connect 或 Debezium Server 来处理数据变更事件。 下面是几种替代方法来实现 MySQ…...
openai swarm agent框架源码详解及应用案例实战
文章目录 简介数据类型Agent类Response类Result类Swarm类run_demo_loop交互式会话 基础应用agent-handsofffunction-callingcontext_variablestriage_agent 高阶应用通用客服机器人(support bot)构建航班服务agent 参考资料 openai 在24年10月份开源了一个教育性质的多agents协…...
Qt 5.14.2 学习记录 —— 팔 QWidget 常用控件(3)
文章目录 1、cursor2、font3、toolTip4、focusPolicy5、styleSheet 1、cursor 改变鼠标光标形状。 在Qt Designer界面中,拖一个按钮过来,右边属性面用户可以自己改cursor属性。 代码方法,先拖一个按钮到界面上: #include <Q…...
Nginx (40分钟学会,快速入门)
目录 一、什么是Nginx ? 可以做什么 ? 二、正向代理和反向代理 三、负载均衡 四、动静分离 五、Nginx 常用命令 六、Nginx实战及总结 一、什么是Nginx ? 可以做什么 ? Nginx 是高性能的 HTTP 和反向代理的 web 服务器,…...
C# 中await和async的用法(一)
在 C# 中,await 关键字用于异步编程,配合 async 方法一起使用。await 允许你等待异步操作完成,而不会阻塞当前线程。简而言之,await 会暂停当前方法的执行,直到任务完成,然后继续执行。 1. await与async的关…...
前端JS中var、let、const之间的区别
🎬 江城开朗的豌豆:个人主页 🔥 个人专栏 :《 VUE 》 《 javaScript 》 📝 个人网站 :《 江城开朗的豌豆🫛 》 ⛺️ 生活的理想,就是为了理想的生活 ! 目录 一、var 二、let 三、const 四、区别 变量…...
【pyqt】(八)ui文件使用
ui文件使用 前面我们已经学过了简单的UI文件创建(利用Qt Designer)和基础控件的使用。现在我们学习如何把二者融合起来完成开发。UI文件以 XML 格式存储界面的布局和各种控件的属性,我们可以利用Qt Designer开发界面,然后利用代码…...
H2数据库在单元测试中的应用
H2数据库特征 用比较简洁的话来介绍h2数据库,就是一款轻量级的内存数据库,支持标准的SQL语法和JDBC API,工业领域中,一般会使用h2来进行单元测试。 这里贴一下h2数据库的主要特征 Very fast database engineOpen sourceWritten…...
ios越狱脚本巨魔商店安装教程
使用爱思助手安装 安装爱思助手:在电脑上安装 iTunes 和爱思助手,并使用 Apple ID 登录2。 IPA 签名:打开爱思助手,选择工具箱中的 IPA 签名。点击添加 IPA 文件,选择下载的 TrollInstallerX.ipa 文件。选择使用 Apple…...
Linux C编程——文件IO基础
文件IO基础 一、简单的文件 IO 示例二、文件描述符三、open 打开文件1. 函数原型2. 文件权限3. 宏定义文件权限4. 函数使用实例 四、write 写文件五、read 读文件六、close 关闭文件七、Iseek 绍 Linux 应用编程中最基础的知识,即文件 I/O(Input、Outout…...
【Rust自学】10.4. trait Pt.2:trait作为参数和返回类型、trait bound
喜欢的话别忘了点赞、收藏加关注哦,对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 说句题外话,写这篇的时间比写所有权还还花的久,trait是真的比较难理解的概念。 10.4.1. 把trait作为参数 继续以…...
Java 中的 getDeclaredMethod() 方法:使用与原理详解
在 Java 反射机制中,getDeclaredMethod() 是一个非常重要的方法,用于获取类中声明的特定方法(包括公共、保护、默认和私有方法)。与 getMethod() 不同,getDeclaredMethod() 可以访问类的所有方法,而不仅仅是…...
解决npm报错:sill idealTree buildDeps
版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl 报错信息 使用 npm 安装依赖时报错:sill idealTree buildDeps 解决方案 请按照以下步骤进行相关操作: 1、删除 C:\Users{账户}\ 文件夹中的 .npm…...
【游戏设计原理】55 - 风险评估
从本文讲述的内容来看,其实使用“游戏中的决策”作为标题更合适。 核心观点:玩家在游戏中不断进行决策,这些决策涵盖风险评估、资源分配、策略选择等多个方面,其核心是通过选择实现最大化回报或最小化损失。关键内容:…...
【AI日记】25.01.08
【AI论文解读】【AI知识点】【AI小项目】【AI战略思考】【AI日记】【读书与思考】 AI 参加:kaggle 比赛 Forecasting Sticker Sales 读书 书名:国家为什么会失败阅读原因:2024 年诺贝尔经济学奖得主的力作未删减版:https://boo…...
SAP BC 同服务器不同client之间的传输SCC1
源配置client不需要释放 登录目标client SCC1...
用Cline打造你的智能搜索助手:Tavily Search MCP集成指南
引言 本文将详细介绍如何在Cline编辑器中集成Tavily Search智能搜索功能。我们将从MCP(Model Context Protocol)协议基础开始,深入探讨Tavily Search MCP服务器的安装配置、使用方法,以及进阶的二次开发技巧。无论你是AI开发者还…...
未来商贸物流:人工智能与大数据的深度融合
未来商贸物流:人工智能与大数据的深度融合 在当今数字化浪潮汹涌澎湃的时代,商贸物流行业正站在变革的十字路口,而人工智能与大数据宛如一对闪耀的双子星,为其照亮前行的道路,深度融合之下,一个全新的未来…...
网络安全、Web安全、渗透测试之笔经面经总结(三)
本篇文章涉及的知识点有如下几方面: 1.什么是WebShell? 2.什么是网络钓鱼? 3.你获取网络安全知识途径有哪些? 4.什么是CC攻击? 5.Web服务器被入侵后,怎样进行排查? 6.dll文件是什么意思,有什么…...
BMS应用软件开发 — 3 电池系统的组成
目录 1 电池的基本拓扑 2 已经被淘汰的CTM 3 早已经普及的CTP 4 集成度更高的CTC 5 刚性更好的CTB 1 电池的基本拓扑 相比于燃油车,虽然电动车在结构空间上灵活度更高,空间利用率也更好,但现有条件下无法像燃油车一样快速补能ÿ…...
springboot 项目使用nacos注册中心配置,在windows系统下打jar包后不能启动的一个不好排查的问题
起因,一个项目使用的nacos注册中心配置,想学习运维一些知识,项目在本地idea,无论是run,debug模式,都可以正常运行。就学习如何打包,打包好后,如何运jar包,都启动不起来&a…...
Git撤销指定commit并更新远端仓库
Git撤销指定commit并更新远端仓库 一、撤销指定commit 1.首先执行git log 命令,查看git历史提交以及commit信息: 由于需要脱敏,所以截图可能看得马赛克比较多,需要关注的就是上面的commit后跟的id,以及HEAD当前指定…...
校园约拍微信小程序设计与实现ssm+论文源码调试讲解
4 系统设计 校园约拍微信小程序的设计方案比如功能框架的设计,比如数据库的设计的好坏也就决定了该系统在开发层面是否高效,以及在系统维护层面是否容易维护和升级,因为在系统实现阶段是需要考虑用户的所有需求,要是在设计阶段没…...
开源靶场1
我来为您介绍一些知名的开源漏洞靶场平台: DVWA (Damn Vulnerable Web Application) 最流行的 Web 漏洞靶场之一包含 SQL 注入、XSS、文件包含等常见漏洞基于 PHP MySQL适合 Web 安全入门学习 WebGoat OWASP 开源项目基于 Java包含大量 Web 安全漏洞练习提供详细的教程和解…...
iOS开发指南:保护服务器密码的安全存储与处理技巧
在iOS开发过程中,服务器密码的安全存储与处理是确保应用安全性的关键环节。不当的密码管理可能导致数据泄露、用户隐私受损,甚至引发更严重的安全问题。因此,开发者需要采取一系列措施来保护服务器密码的安全。本文将详细介绍在iOS开发中如何…...