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

数据结构 - 9( 位图 布隆过滤器 并查集 LRUCache 6000 字详解 )

一:位图

位图是一种高效的数据结构,它通过比特来表示某个值的存在与否,通常以连续的二进制位数组存储。每个比特位对应一个特定的状态,这种表示方式在内存效率和操作速度上具有显著优势,尤其适用于海量数据、整数以及数据不重复的场景。位图一般用于快速判断某个数据是否存在。

小技巧:10 亿个字节大概是 0.9 G,可看做是 1 G,10 亿个比特位大概是 119 兆,看做 128 兆

1.1 位图的实现

public class MyBitSet {private byte[] elem; // 存储位的数组,每个元素是一个字节public int usedSize; // 已使用的比特位数量// 默认构造函数,初始化大小为1的字节数组public MyBitSet() {elem = new byte[1];}// 根据指定的比特位数量 n 初始化字节数组public MyBitSet(int n) {elem = new byte[n / 8 + 1]; // 确保有足够的字节来存储 n 个比特位}// 将指定值 val 对应的比特位设置为 1public void set(int val) {if (val < 0) {throw new IndexOutOfBoundsException(); // 检查 val 是否为负}int arrayIndex = val / 8; // 计算对应的字节索引int bitIndex = val % 8; // 计算比特位在字节中的位置this.elem[arrayIndex] |= (1 << bitIndex); // 将对应的比特位设置为 1usedSize++; // 增加已使用的比特计数}// 检查指定值 val 对应的比特位是否为 1public boolean get(int val) {if (val < 0) {throw new IndexOutOfBoundsException(); // 检查 val 是否为负}int arrayIndex = val / 8; // 计算对应的字节索引int bitIndex = val % 8; // 计算比特位在字节中的位置return (this.elem[arrayIndex] & (1 << bitIndex)) != 0; // 返回该比特位的状态}// 将指定值 val 对应的比特位设置为 0public void reSet(int val) {if (val < 0) {throw new IndexOutOfBoundsException(); // 检查 val 是否为负}int arrayIndex = val / 8; // 计算对应的字节索引int bitIndex = val % 8; // 计算比特位在字节中的位置this.elem[arrayIndex] &= ~(1 << bitIndex); // 将对应的比特位设置为 0usedSize--; // 减少已使用的比特计数}// 返回当前已使用比特位的数量public int getUsedSize() {return this.usedSize; // 返回已使用的比特位数量}
}

1.2 位图的应用

  1. 快速判断某个数据是否在集合中。
  2. 对集合进行排序和去重。
  3. 计算两个集合的交集和并集。
  4. 在操作系统中进行磁盘块的标记管理。

二:布隆过滤器

2.1 布隆过滤器的概念

布隆过滤器是由布隆(Burton Howard Bloom)于1970年提出的一种紧凑且高效的概率型数据结构。其特点在于快速的插入和查询操作,能够判断某个元素“一定不存在”或“可能存在”。它通过多个哈希函数将数据映射到位图中。这种方式不仅提高了查询效率,还显著节省了内存空间。

在这里插入图片描述

2.2 布隆过滤器的插入

在这里插入图片描述
现在向布隆过滤器中插入 baidu:

在这里插入图片描述

在这里插入图片描述

通过定义的三个哈希函数,接着对字符串 baidu 进行哈希运算。这些哈希函数会生成三个索引值,接着把对应位置标记为 1,所以当你当需要判断某个元素是否在布隆过滤器中时,首先同样通过哈希函数计算出对应的索引,接着判断这些索引是不是都是 1,如果是的话说明这个东西可能存在,如果有一个不是 1,那么就说明这个东西一定不存在。

注意:布隆过滤器可以准确地判断某个元素“绝对不存在”,但如果判断某个元素“可能存在”,则可能出现误判。这是因为哈希函数可能导致冲突,从而使得某些不存在的元素被误认为可能存在。

2.3 布隆过滤器模拟实现

import java.util.BitSet;// 构建哈希函数类
class SimpleHash {private int cap;  // 位图的容量private int seed; // 随机种子// 构造函数,初始化容量和随机种子public SimpleHash(int cap, int seed) {this.cap = cap;this.seed = seed;}// 将字符串转变为一个哈希值public int hash(String value) {int result = 0;int len = value.length();// 遍历字符串的每个字符for (int i = 0; i < len; i++) {result = seed * result + value.charAt(i); // 基于种子的哈希计算}return (cap - 1) & result; // 返回哈希值,确保结果在位图范围内}
}// 布隆过滤器类
public class BloomFilter {private static final int DEFAULT_SIZE = 1 << 24; // 默认位图大小private static final int[] seeds = new int[]{5, 7, 11, 13, 31, 37, 61}; // 多个哈希函数的种子private BitSet bits;        // 位图用于存储元素private SimpleHash[] func;  // 哈希函数数组private int size = 0;      // 已存储元素数量// 构造函数,初始化位图和哈希函数public BloomFilter() {bits = new BitSet(DEFAULT_SIZE); // 初始化位图func = new SimpleHash[seeds.length]; // 初始化哈希函数数组// 为每个种子创建一个哈希函数for (int i = 0; i < seeds.length; i++) {func[i] = new SimpleHash(DEFAULT_SIZE, seeds[i]);}}// 向布隆过滤器中添加元素public void set(String value) {if (value == null) return; // 检查值是否为null// 对每个哈希函数计算对应的位图位置并设置为1for (SimpleHash f : func) {bits.set(f.hash(value));}size++; // 增加已存储元素的计数}// 判断某个元素是否存在于布隆过滤器中public boolean contains(String value) {if (value == null) return false; // 检查值是否为null// 检查所有哈希函数对应的位图位置for (SimpleHash f : func) {if (!bits.get(f.hash(value))) { // 若有任何位置为0,则确定不存在return false;}}return true; // 若所有位置均为1,返回可能存在(存在误判的可能性)}
}

布隆过滤器不能直接支持删除工作,因为在删除一个元素时,可能会影响其他元素。

三:并查集

在某些应用场景中,需要将 n 个不同元素划分为若干个不相交的集合。最初,每个元素自成一个单元素集合,之后根据一定的规则合并属于同一组的元素。在这个过程中,需要反复查询某个元素所属的集合。这种适用于描述此类问题的抽象数据类型称为并查集。

  1. 这是最初的状态:
    在这里插入图片描述

  2. 这里划分成了 3 个集合
    在这里插入图片描述
    在这里插入图片描述

  3. 这里又合并了两个集合

在这里插入图片描述
在 0 集合有 7 个人,2 集合有 3 个人,总共两个集合。通过以上例子可知,并查集一般可以解决一下问题:

  1. 查找元素所属集合:沿着数组表示的树形结构,递归向上查找,直到找到根节点,即数组中值为负数的位置。

  2. 判断两个元素是否在同一集合:沿着树形结构向上查找两个元素的根节点。如果根节点相同,则说明这两个元素属于同一个集合;否则,它们不在同一集合中。

  3. 合并两个集合:将两个集合的元素合并为一个集合,并将一个集合的名称替换为另一个集合的名称。

  4. 计算集合个数:遍历数组,统计其中特殊元素(值为负数)的数量,这个数量便是当前集合的个数。

3.1 并查集实现

package unionfindset;import java.util.Arrays;public class UnionFindSet {private int[] elem; // 用于存储集合信息的数组// 构造函数,初始化并查集public UnionFindSet(int n) {this.elem = new int[n]; // 创建一个大小为 n 的数组Arrays.fill(elem, -1); // 初始化所有元素为 -1,表示每个元素自成一个集合}// 查找元素 x 的根节点public int findRoot(int x) {// 检查参数是否合法if (x < 0 || x >= elem.length) {throw new IndexOutOfBoundsException("数据不合法");}// 通过不断向上查找直到找到根节点while (elem[x] >= 0) {x = elem[x];}return x; // 返回根节点}// 合并两个集合,x1 和 x2 必须是它们各自的根节点public void union(int x1, int x2) {int index1 = findRoot(x1); // 查找 x1 的根节点int index2 = findRoot(x2); // 查找 x2 的根节点if (index1 == index2) return; // 如果两个元素已经在同一个集合中,则不需要合并// 合并两个集合,更新元素统计elem[index1] = elem[index1] + elem[index2]; // 更新根节点的大小elem[index2] = index1; // 将 x2 的根指向 x1 的根}// 判断两个元素是否在同一个集合中public boolean isSameSet(int x1, int x2) {int index1 = findRoot(x1); // 查找 x1 的根节点int index2 = findRoot(x2); // 查找 x2 的根节点return index1 == index2; // 返回根节点是否相同}// 获取当前集合的个数public int getCount() {int count = 0; // 初始化集合计数// 遍历 elem 数组,统计根节点的数量for (int x : elem) {if (x < 0) {count++; // 每当找到一个根节点,计数器加一}}return count; // 返回集合总数}// 打印当前集合的信息public void printArr() {for (int i = 0; i < elem.length; i++) {System.out.print(elem[i] + " "); // 打印每个元素的值}System.out.println(); // 打印新行}
}

四:LRUCache

LRU(Least Recently Used,最近最少使用)是一种缓存替换算法。由于缓存 Cache 的容量有限,当缓存满时,需要根据一定原则选择并舍弃部分原有内容,以腾出空间用于存储新内容。LRU缓存的替换原则是替换最近最少使用的内容,因此也可以理解为“最久未使用”,因为该算法每次替换的都是在一段时间内最久没有被使用过的数据。

实现LRU缓存的方法和思路有很多,但要达到高效的 O(1) 时间复杂度的 put 和 get 操作,结合双向链表和哈希表是最经典和高效的方案。双向链表允许在任意位置以 O(1) 的时间复杂度进行插入和删除操作,而哈希表则支持 O(1) 的增删查改。这两种数据结构的结合使得LRU缓存既能够快速访问,也能高效管理缓存中元素的使用顺序。

在这里插入图片描述

4.1 模拟实现 LRUCache

import java.util.HashMap;
import java.util.Map;public class LRUCache {// 定义双向链表节点类class DLinkedNode {int key; // 节点的 keyint value; // 节点的 valueDLinkedNode prev; // 前驱节点DLinkedNode next; // 后继节点// 默认构造函数public DLinkedNode() {}// 带参数的构造函数public DLinkedNode(int _key, int _value) {key = _key;value = _value;}}// 哈希表,用于存储 key 和对应的 DLinkedNode 节点private Map<Integer, DLinkedNode> cache = new HashMap<>();private int size; // 当前缓存的大小private int capacity; // 缓存的最大容量private DLinkedNode head, tail; // 伪头部和伪尾部节点// 构造函数,初始化缓存容量public LRUCache(int capacity) {this.size = 0; // 初始化大小为 0this.capacity = capacity; // 设置缓存的最大容量head = new DLinkedNode(); // 创建伪头部节点tail = new DLinkedNode(); // 创建伪尾部节点head.next = tail; // 头节点的 next 指向尾节点tail.prev = head; // 尾节点的 prev 指向头节点}// 获取缓存中指定 key 的值public int get(int key) {DLinkedNode node = cache.get(key); // 在哈希表中查找 keyif (node == null) { // 如果没有找到,返回 -1return -1;}moveTail(node); // 将找到的节点移动到链表的尾部return node.value; // 返回节点的值}// 将指定节点移动到链表的尾部private void moveTail(DLinkedNode node) {removeNode(node); // 先移除该节点addToTail(node); // 然后将其添加到尾部}// 移除指定节点private void removeNode(DLinkedNode node) {node.prev.next = node.next; // 让前驱节点指向后继节点node.next.prev = node.prev; // 让后继节点指向前驱节点}// 将指定节点添加到链表的尾部private void addToTail(DLinkedNode node) {tail.prev.next = node; // 让当前尾部节点的前驱指向新节点node.next = tail; // 新节点的 next 指向 tail(伪尾部)node.prev = tail.prev; // 新节点的 prev 指向原来的尾部节点tail.prev = node; // 更新尾部节点的 prev 指向新节点}// 添加新元素到缓存public void put(int key, int value) {DLinkedNode node = cache.get(key); // 查找 key 对应的节点if (node == null) { // 如果节点不存在DLinkedNode newNode = new DLinkedNode(key, value); // 创建新节点cache.put(key, newNode); // 将新节点添加到哈希表addToTail(newNode); // 将新节点添加到链表的尾部++size; // 更新当前缓存的大小if (size > capacity) { // 如果超出了容量限制DLinkedNode headNode = removeHead(); // 移除链表的头部节点cache.remove(headNode.key); // 从哈希表中删除对应的 key--size; // 更新当前缓存的大小}} else { // 如果节点已存在node.value = value; // 更新节点的值moveTail(node); // 将该节点移到链表的尾部}}// 删除链表的头部节点(最少使用的节点)private DLinkedNode removeHead() {DLinkedNode ret = head.next; // 获取头部节点head.next = ret.next; // 让伪头部指向下一个节点ret.next.prev = head; // 更新下一个节点的 prev 指向伪头部return ret; // 返回删除的节点}
}

相关文章:

数据结构 - 9( 位图 布隆过滤器 并查集 LRUCache 6000 字详解 )

一&#xff1a;位图 位图是一种高效的数据结构&#xff0c;它通过比特来表示某个值的存在与否&#xff0c;通常以连续的二进制位数组存储。每个比特位对应一个特定的状态&#xff0c;这种表示方式在内存效率和操作速度上具有显著优势&#xff0c;尤其适用于海量数据、整数以及…...

在Hugging Face网站像Github一样克隆repository到本地的具体步骤

首先我们找到自己想要的仓库&#xff0c;在搜索栏进行搜索 之后我们可以看到这里有三个点&#xff0c;鼠标点击&#xff0c;选择Clone repository 最后按照上面的步骤进行复制粘贴到电脑上执行就行&#xff0c;我们可以看到有两种选择HTTPS和SSH&#xff0c;如果HTTPS不行就选择…...

如何使用Java从PDF文件中提取图像(教程)

Java本身不直接支持PDF文件操作&#xff0c;因此需要使用外部Java PDF库。本教程将向您展示如何通过5个简单步骤&#xff0c;使用JPedal Java PDF库从PDF文件中提取图像。 使用Java从PDF中提取图像 • 将JPedal库添加到您的类路径或模块路径&#xff08;下载试用版jar文件&…...

通过混合机器学习和 TOPSIS 实现智能手机身份验证的稳健行为生物识别框架

1. 简介 随着日常工作、个人生活和金融操作对智能手机的依赖性不断增强,对弹性安全身份验证系统的需求也日益增长。尽管 PIN 码、密码和静态生物识别等传统身份验证方法仍可为系统提供一定的安全级别,但事实证明,它们容易受到多种威胁,包括敏感数据泄露、网络钓鱼、盗窃和…...

day010

文章目录 1. 在Ubuntu中使用visudo2. 别名 alias2.1 查看已配置的别名2.2 配置grep别名2.3 配置rm别名2.4 临时使用配置别名的命令 3. 系统校验检查3.1 md5校验3.2 aide 高级入侵检测环境3.2.1 安装aide3.2.2 修改aide配置文件3.2.3 根据配置文件生成初始的指纹信息库3.2.4 使用…...

Coco AI 开源应用程序 - 搜索、连接、协作、您的个人 AI 搜索和助手,都在一个空间中。

一、软件介绍 文末提供程序和源码下载 Coco AI 是一个统一的搜索平台&#xff0c;可将您的所有企业应用程序和数据&#xff08;Google Workspace、Dropbox、Confluent Wiki、GitHub 等&#xff09;连接到一个功能强大的搜索界面中。此存储库包含为桌面和移动设备构建的 Coco 应…...

MySQL 8.0 OCP(1Z0-908)英文题库(11-20)

目录 第11题题目分析正确答案 第12题题目分析正确答案 第13题题目分析正确答案 第14题题目分析正确答案 第15题题目分析正确答案 第16题题目分析正确答案 第17题题目分析正确答案&#xff1a; 第18题题目分析正确答案 第19题题目分析正确答案 第20题题目分析正确答案 第11题 W…...

国标GB28181软件EasyGBS雪亮工程打造智能高效的视频监控新体系

一、背景 雪亮工程是构建公共安全视频监控联网应用的系统工程&#xff0c;旨在通过整合各类视频监控资源&#xff0c;实现城乡视频监控一体化&#xff0c;提升社会治安防控能力。随着城市化进程的加快和社会治理需求的不断提高&#xff0c;雪亮工程的建设规模不断扩大&#xf…...

视频添加字幕脚本分享

脚本简介 这是一个给视频添加字幕的脚本&#xff0c;可以方便的在指定的位置给视频添加不同大小、字体、颜色的文本字幕&#xff0c;添加方式可以直接修改脚本中的文本信息&#xff0c;或者可以提前编辑好.srt字幕文件。脚本执行环境&#xff1a;windowsmingwffmpeg。本方法仅…...

springCloud/Alibaba常用中间件之GateWay网关

文章目录 SpringCloud:依赖版本补充GateWay:网关三大核心之Router:路由1、导入基础依赖2、进行服务注册3、路由映射4、测试访问GateWay的端口是否可以访问 三大核心之Predicate:断言配置文件自定义Predicate&#xff08;断言&#xff09; 三大核心之Filter:过滤配置文件自定义全…...

ABP vNext + Dapr 实现云原生微服务治理

ABP vNext Dapr 实现云原生微服务治理 &#x1f680; 前言 &#x1f4dd; 随着云原生与微服务架构的快速发展&#xff0c;相关工具和框架也在不断演进。ABP vNext 是一套成熟而现代的 .NET 应用开发框架&#xff0c;在模块化、领域驱动设计等方面提供强大支持。而 Dapr 作为…...

【报错】view size is not compatible with input tensor‘s size and stride

完整报错 Traceback (most recent call last): File "D:\360MoveData\Users\HONOR\whu\TwoStageTraining.py", line 590, in <module> criterionseg_criterion, save_dir./models, writerwriter_first_stage) File "D:\360MoveData\Users\HONOR\whu\TwoS…...

maven如何搭建自己的私服(windows版)?

环境准备 安装 JDK &#xff1a;确保系统已安装 JDK 8 或更高版本。可以通过以下步骤安装 JDK&#xff1a; 下载 JDK 安装包&#xff0c;可以从Oracle 官方网站下载适用于 Windows 的 JDK 安装程序。 运行安装程序&#xff0c;按照提示完成安装。安装过程中可以指定安装路径&a…...

CDGP|数据全生命周期的“收数、治数、用数、保数”体系详解

在数据成为重要资产的今天&#xff0c;如何高效地管理和利用数据已成为企业和组织的核心竞争力之一。数据全生命周期管理涵盖了从数据收集、治理、应用到保护的各个环节&#xff0c;形成了一个闭环体系。本文将重点介绍数据全生命周期中的“收数、治数、用数、保数”四个关键环…...

在UI原型设计中,低、高保真原型图有什么区别?

在数字产品开发中&#xff0c;原型&#xff08;Prototype&#xff09; 是连接创意与落地的桥梁。它通过可视化的方式验证功能、交互与用户体验&#xff0c;避免开发资源浪费。而低保真&#xff08;Lo-Fi&#xff09;与高保真&#xff08;Hi-Fi&#xff09;原型&#xff0c;则是…...

万物互联时代:ONVIF协议如何重构安防监控系统架构

前言 一、ONVIF协议是什么 ONVIF&#xff08;Open Network Video Interface Forum&#xff0c;开放式网络视频接口论坛&#xff09;是一种全球性的开放行业标准&#xff0c;由安讯士&#xff08;AXIS&#xff09;、博世&#xff08;BOSCH&#xff09;和索尼&#xff08;SONY&…...

初识Linux · 传输层协议TCP · 上

目录 前言&#xff1a; TCP结构体 首部长度 确认应答机制 捎带应答机制 超时重传机制 连接管理机制 三次握手 SYN_SENT SYN_RCVD ESTABLISHED TCP为什么是三次握手 四次挥手 什么是四次挥手 状态理解 CLOSE_WAIT LAST_ACK TIME_WAIT 前言&#xff1a; 前文有…...

基于SpringBoot的校园周边美食探索及分享平台的设计与实现

资源详情&#xff1a; 私信我或点击链接获取&#xff1a; 基于SpringBoot的校园周边美食探索及分享平台的设计与实现资源-CSDN文库 摘要 美食一直是与人们日常生活息息相关的产业。传统的电话订餐或者到店消费已经不能适应市场发展的需求。随着网络的迅速崛起&#xff0c;互联…...

系统架构设计-真题2024下半年总结

系统架构设计-真题2024下半年总结 综合知识&#xff08;选择题&#xff09;考点分布选择题详细解释ABSD方法简介 选项分析生活化例子概念讲解系统的质量目标系统的商业目标系统开发人员的商业目标 简单记法总结基于内容推荐的优点选项分析正确答案总结 综合知识&#xff08;选择…...

《React Native性能优化:从卡顿到丝滑的蜕变之旅》

《React Native性能优化:从卡顿到丝滑的蜕变之旅》 前言:当你的React Native应用开始"便秘"… “这破应用怎么又卡了?!”——如果你也曾在测试自己的React Native应用时发出这样的呐喊,那么你不是一个人在怒吼。想象一下这样的场景:你精心打造的APP在低端安卓…...

flutter build apk出现的一些奇怪的编译错误

我换了新电脑后重新编译基于livekit 的 flutter livekit工程&#xff0c;然后编译的时候一直报flutter_webrtc的 0.11.7 版本的dart代码有一个接口未实现&#xff0c;我比较了所以环境和版本实现找不到问题&#xff0c;根本不正常哪里导致的问题 &#xff0c;以前的电脑的环境一…...

枚举 · 例8扩展-校门外的树:hard

登录—专业IT笔试面试备考平台_牛客网 代码区&#xff1a; #include<algorithm> #include<iostream> #include<vector>using namespace std; struct TREE{int left,right; }; bool compare(const TREE&a,const TREE& b ){if(a.left!b.left){return…...

监控系统进阶方案:OpenObserve的Docker部署与远程访问配置指南

文章目录 前言1. 安装Docker2. 创建并启动OpenObserve容器3. 本地访问测试4. 公网访问本地部署的OpenObserve4.1 内网穿透工具安装4.2 创建公网地址 5. 配置固定公网地址 前言 今天&#xff0c;我想分享一个在云原生可观测性领域备受关注的开源项目——OpenObserve。在复杂的云…...

如何通过grep 排除“INTEGER: 1”

在 Linux/Unix 系统中&#xff0c;使用 grep 过滤数据并 取反&#xff08;排除匹配内容&#xff09; 的核心选项是 -v&#xff08;反向匹配&#xff09;。以下是具体用法和场景示例&#xff1a; 1. 基础用法&#xff1a;排除包含指定关键词的行 # 语法 grep -v "pattern&…...

基于Qt开发的http/https客户端

成果展示&#xff1a; 使用Qt开发HTTP客户端主要依赖QNetworkAccessManager、QNetworkRequest和QNetworkReply三大核心类。以下是具体实现要点及最佳实践&#xff1a; 一、核心类与基础流程​​ 1.QNetworkAccessManager​​ 作为HTTP请求的管理者&#xff0c;负责异步处理…...

微程序控制器的详细工作过程

1. 基本组成结构 微程序控制器主要由以下部件构成&#xff1a; 控制存储器&#xff08;Control Store, CS&#xff09;&#xff1a;存储微程序&#xff08;微指令集合&#xff09;&#xff0c;通常使用ROM或EPROM。 微地址寄存器&#xff08;μAR&#xff09;&#xff1a;存放…...

PostgreSQL 的 pg_current_logfile 函数

PostgreSQL 的 pg_current_logfile 函数 pg_current_logfile() 是 PostgreSQL 9.6 版本引入的一个系统管理函数&#xff0c;用于获取当前正在使用的日志文件路径。 一 基本用法 1 函数定义 pg_current_logfile([text]) → text2 简单查询 -- 获取当前日志文件路径 SELECT …...

实时云渲染——比像素流送节省80%精力的UE程序推流技术

UE5引擎除了适合开发3A游戏&#xff0c;同样适用于开发大场景高精度的数字孪生可视化场景&#xff0c;自带的Nanite 虚拟微多边形几何体技术、Lumen 全动态全局光照技术、高度可扩展的架构、强大的地形和植被系统以及高效的流媒体技术&#xff0c;使UE5在数字孪生领域的技术占有…...

如何解决 Linux 系统文件描述符耗尽的问题

在Linux系统中&#xff0c;文件描述符&#xff08;File Descriptor, FD&#xff09;是操作系统管理打开文件、套接字、管道等资源的抽象标识。当进程或系统耗尽文件描述符时&#xff0c;会导致服务崩溃、连接失败等严重问题。以下是详细的排查和解决方案&#xff1a; --- ###…...

存储器:DDR和HBM的区别

本文简要介绍DDR&#xff08;Double Data Rate SDRAM&#xff09;和HBM&#xff08;High Bandwidth Memory&#xff09;的主要区别&#xff1a; 1. 架构与设计 DDR&#xff1a;传统的主流动态随机存取存储器&#xff08;DRAM&#xff09;&#xff0c;采用并行总线架构&#x…...

【计算机网络】Cookie、Session、Token之间有什么区别?

大家在日常使用浏览器时可能会遇到&#xff1a;是否清理Cookie&#xff1f;这个问题。 那么什么是Cookie呢&#xff1f;与此相关的还有Session、Token这些。这两个又是什么呢&#xff1f; 本文将对这三个进行讲解区分&#xff0c;如果对小伙伴有帮助的话&#xff0c;也请点赞、…...

每日学习:DAY24

日常开发与学习记录 前言 怎么感觉自己越来越懒了。 日程 忘记写了&#xff0c;大概是早上做了 SQL 表单&#xff0c;晚上写了 DispatcherController。 学习记录 操作系统 页面分配置换策略 学习内容 省流 SQL 表单构建关于嵌套注解的生效机制DispatcherController 统…...

grpo原理

图解deepseek的grpo原理、以debug形式阅读grpo的源码 练习两天半&#xff0c;从零实现DeepSeek-R1&#xff08;基于Qwen2.5-0.5B和规则奖励模型&#xff0c;GRPO&#xff09;&#xff0c;从原理讲解到代码实现&#xff0c;解开DeepSeek-R1的神秘面纱 第一个视频 GRPO讲解 mod…...

RabbitMQ--基础篇

RabbitMQ 简介&#xff1a;RabbitMQ 是一种开源的消息队列中间件&#xff0c;你可以把它想象成一个高效的“邮局”。它专门负责在不同应用程序之间传递消息&#xff0c;让系统各部分能松耦合地协作 优势&#xff1a; 异步处理&#xff1a;比如用户注册后&#xff0c;主程序将发…...

ResNet残差神经网络的模型结构定义(pytorch实现)

ResNet残差神经网络的模型结构定义&#xff08;pytorch实现&#xff09; ResNet‑34 ResNet‑34的实现思路。核心在于&#xff1a; 定义残差块&#xff08;BasicBlock&#xff09;用 _make_layer 方法堆叠多个残差块按照 ResNet‑34 的通道和层数配置来搭建网络 import torch…...

如何使用极狐GitLab 软件包仓库功能托管 ruby?

极狐GitLab 是 GitLab 在中国的发行版&#xff0c;关于中文参考文档和资料有&#xff1a; 极狐GitLab 中文文档极狐GitLab 中文论坛极狐GitLab 官网 软件包库中的 Ruby gems (BASIC ALL) WARNING:Ruby gems 软件包库正在开发中&#xff0c;由于功能有限&#xff0c;尚未准备好…...

AI日报 · 2025年5月08日|Stripe发布全球首个支付AI基础模型

1、Stripe 发布支付领域专用 AI 基础模型及稳定币账户功能 Stripe 于5月7日在其年度 Sessions 大会上发布了全球首个专为支付领域打造的 AI 基础模型——“Payments Foundation Model”&#xff0c;该模型基于数百亿笔交易数据训练&#xff0c;能够捕捉每个支付中数百个传统模…...

React 笔记[1] hello world

React 笔记[1] hello world 明白了&#xff01;既然你已经安装了 Node.js&#xff0c;我们可以 从零开始搭建一个 React Tailwind CSS 的 Hello World 项目。我将一步步列出操作指令&#xff0c;你只需要在终端里依次执行。 ✅ 第一步&#xff1a;初始化项目 mkdir my-hello…...

好消息!PyCharm 社区版现已支持直接选择 WSL 终端为默认终端

在过去&#xff0c;PyCharm 社区版虽然提供了链接 Windows 子系统 Linux&#xff08;WSL&#xff09;终端的能力&#xff0c;但用户无法在设置中直接指定 WSL 为默认终端&#xff0c;这一功能仅限于专业版使用者。 而现在&#xff0c;在 PyCharm 2025.1.1 版本中&#xff0c;Je…...

基于redis的定时状态更新

基于redis的定时状态更新 下面是一个简单的示例&#xff0c;展示如何使用redis实现状态更新&#xff0c;从而满足在某些场景下&#xff0c;既需要频繁更新状态&#xff0c; 又需要保证状态的实时性。以及定时更新状态的需求。 示例说明 假设有一个剧目演出计划&#xff0c;确…...

[原创](现代Delphi 12指南):[macOS 64bit App开发]: 如何获取自身程序的所在的目录?

[作者] 常用网名: 猪头三 出生日期: 1981.XX.XX 企鹅交流: 643439947 个人网站: 80x86汇编小站 编程生涯: 2001年~至今[共24年] 职业生涯: 22年 开发语言: C/C++、80x86ASM、Object Pascal、Objective-C、C#、R、Python、PHP、Perl、 开发工具: Visual Studio、Delphi、XCode、…...

服务器托管的常见问题

一、何谓IDC服务器托管服务? IDC服务器托管是指为了提高网站的访问速度&#xff0c;将您的服务器及相关设备托管到具有完善机房设施、高品质网络环境、丰富带宽资源和运营经验以及可对用户的网络和设备进行实时监控的网络数据中心内&#xff0c;以此使系统达到安全、可靠、稳定…...

使用Scrapeless Scraping Browser的自动化和网页抓取最佳实践

引言&#xff1a;人工智能时代浏览器自动化和数据收集的新范式 随着生成性人工智能、人工智能代理和数据密集型应用程序的快速崛起&#xff0c;浏览器正在从传统的“用户互动工具”演变为智能系统的“数据执行引擎”。在这一新范式中&#xff0c;许多任务不再依赖单一的API端点…...

电子电气架构 --- 如何有助于提安全性并减少事故

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 钝感力的“钝”,不是木讷、迟钝,而是直面困境的韧劲和耐力,是面对外界噪音的通透淡然。 生活中有两种人,一种人格外在意别人的眼光;另一种人无论…...

【训练】Qwen2.5VL 多机多卡 Grounding Box定位

之前的相关文章&#xff1a; 【深度学习】LLaMA-Factory微调sft Qwen2-VL进行印章识别 https://www.dong-blog.fun/post/1661 使用LLaMA-Factory微调sft Qwen2-VL-7B-Instruct https://www.dong-blog.fun/post/1762 构建最新的LLaMA-Factory镜像 https://www.dong-blog.f…...

MYSQL的行级锁到底锁的是什么东西

MySQL 的行级锁是一种锁机制&#xff0c;它允许数据库在执行并发操作时&#xff0c;锁定表中的某一行数据而不是整张表。行级锁通过限制对特定行的访问&#xff0c;允许其他线程并发地访问表中的其他行&#xff0c;从而提高并发性和性能。 行级锁的锁定对象 行级锁锁定的是 行…...

图神经网络中的虚拟节点

1.虚拟节点 当我们使用节点来构成图结构时&#xff0c; regular node: 常规的节点即代表了某一个局部特征&#xff0c; 即局部节点特征。 virtual node&#xff1a; 普通的节点不同&#xff0c;有时会需要这样的一种特征&#xff0c; 该特征代表了该样本的全局信息&#xff0…...

关于多版本CUDA共存的研究,是否能一台机子装两个CUDA 版本并正常切换使用

我发现了一个很有意思的事 我装了11.8cuda再装12.3cuda结果我的11.8cuda还在&#xff0c;没被替换掉或者删掉 然后我打开我的环境发现它的环境除了cuda_path都没改 这样我就有个大胆的想法&#xff0c;如果我把cuda path换成11.8路径那是不是就能切换了 而且cuda_path 和 cuda_…...

el-table与echarts图形实现滚动联动

el-table与echarts图形滚动联动 效果图 实现思路 设计图滚动条位于表格下方&#xff0c;且echarts滚动不易获取当前展示数据到左侧的距离 故&#xff1a;通过监听表格的滚动实现联动 为了保持echarts的横坐标和表格的列基本保持对齐&#xff0c;用tdWidth标识单列表格的宽度…...

【Git】【commit】查看未推送的提交查看指定commit的修改内容合并不连续的commit

文章目录 1. 查看未推送的提交方法一 &#xff1a;git status方法二&#xff1a;git log方法三&#xff1a;git cherry方法四&#xff1a;git rev-list 2. 查看指定commit的修改方法一&#xff1a;git show方法二&#xff1a;git log方法三&#xff1a;git diff 3. 合并不连续的…...