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

【面试题系列】(一)

Redis有哪些数据结构?其底层是怎么实现的?

Redis 系列(一):深入了解 Redis 数据类型和底层数据结构

alt
  1. 字符串(String): 用于存储文本或二进制数据。可以执行字符串的基本操作,如设置、获取、增加、减少等。

  2. 哈希表(Hash): 存储键值对集合,类似于关联数组。适用于存储对象属性或配置信息。

  3. 列表(List): 使用双向链表实现的有序集合,允许插入和删除元素。可以用于实现队列、栈等数据结构。

  4. 集合(Set): 存储不重复的无序元素集合。支持求交集、并集、差集等操作,适用于数据去重和关联性操作。

  5. 有序集合(Sorted Set): 类似于集合,但每个元素都有一个分数(score),并根据分数进行排序。适用于排行榜、优先级队列等场景。

  6. 位图(Bitmap): 使用字符串来表示位的数据结构,支持位操作。适用于标记、计数等场景。

  7. HyperLogLog: 用于估计集合中唯一元素的个数,占用固定的内存空间,适用于基数统计场景。

  8. 地理空间(GeoSpatial): 存储地理位置信息,支持距离计算和位置查询。

什么是缓存击穿?什么原因?如何解决?

缓存击穿是指在高并发情况下,一个缓存中不存在但是频繁被请求的数据,导致请求直接打到数据库,增加数据库的负载和延迟。这通常发生在以下情况下:

  1. 热点数据失效: 当某个热点数据过期或被移除时,大量的并发请求同时访问该数据,导致请求绕过缓存直接访问数据库。

  2. 分布式系统中的节点失效: 在分布式缓存环境下,如果一个或多个缓存节点失效,会导致请求无法命中缓存,从而打到后端数据库。

解决缓存击穿的方法有多种,其中常见的包括:

  1. 设置热点数据永不过期: 对于热点数据,可以设置永不过期,确保数据始终可用。但要注意,这会占用缓存空间,可能导致其他数据的驱逐。

  2. 使用互斥锁(Mutex Lock): 在缓存失效时,使用互斥锁来控制只有一个请求能够从数据库加载数据,其他请求在等待中,避免并发访问数据库。

  3. 提前异步加载: 在数据即将过期时,启动一个异步任务去加载数据到缓存,避免过期时直接请求数据库。

  4. 使用分布式锁: 在分布式环境下,可以使用分布式锁来保护缓存数据的加载过程,确保只有一个节点进行加载。

  5. 使用布隆过滤器: 布隆过滤器是一种用于判断元素是否存在于集合中的数据结构,可以用来判断某个数据是否需要去数据库加载,减少无效的请求。

  6. 热点数据预加载: 提前在系统启动时加载热点数据到缓存,避免在运行时因为缓存失效而引起的问题。

选择哪种方法取决于具体的业务场景和需求,通常需要根据系统的特点和访问模式来综合考虑。

什么是缓存雪崩?什么原因?如何解决?

缓存雪崩是指缓存在某个时间段内大面积失效,导致大量请求直接访问后端数据库,造成数据库压力激增和系统性能下降的情况。通常发生在以下情况下:

  1. 大量缓存同时失效: 当多个缓存数据在同一个时间段内同时失效,导致大量请求直接打到后端数据库。

  2. 缓存服务器宕机: 如果缓存服务器宕机,缓存数据不可用,请求会直接访问后端数据库。

  3. 业务高峰期: 在业务高峰期,访问量剧增,缓存失效导致数据库请求激增。

解决缓存雪崩的方法包括:

  1. 使用多级缓存: 引入多级缓存,将数据同时存储在多个缓存层,降低某个缓存层失效的风险。

  2. 设置随机过期时间: 对于相同类型的数据,设置随机的过期时间,避免大量数据同时失效。

  3. 缓存数据永不过期: 对于热点数据,可以设置永不过期,确保数据始终可用。

  4. 异步加载缓存: 在缓存失效时,启动异步任务去加载数据,避免在缓存失效时直接访问数据库。

  5. 限流降级: 在高峰期限制请求的并发数,将部分请求降级处理,避免对后端服务造成过大压力。

  6. 熔断策略: 根据系统负载情况,实施熔断策略,避免系统崩溃。

  7. 缓存预热: 在系统启动时,预先加载热点数据到缓存,避免系统启动时的大量请求。

  8. 分布式部署: 将缓存服务器分布在不同的节点上,降低单点故障的风险。

综合考虑业务需求和系统特点,可以采用上述方法来解决缓存雪崩问题,保障系统的稳定性和性能。

Redis持久化机制了解吗?

Redis 系列(二):深入解读 Redis 的两种持久化方式

是的,Redis具有两种主要的持久化机制:RDB(Redis Database)快照和AOF(Append-Only File)日志。这些机制用于将内存中的数据持久化到硬盘上,以防止数据丢失。

  1. RDB快照:

    • RDB持久化通过将内存中的数据快照保存到一个二进制文件(例如 dump.rdb)中来实现。
    • 可以手动执行RDB快照,也可以通过配置项定期自动执行。
    • 优点是文件小,适合备份和恢复,对性能影响较小。
    • 缺点是数据可能在两次快照之间发生丢失,不适合数据实时性要求较高的场景。
  2. AOF日志:

    • AOF持久化记录每个写操作(例如SET、DEL)到一个追加的日志文件(例如 appendonly.aof)中。
    • AOF文件以文本方式记录,可以随时对其进行追加、更新和重写。
    • 可以通过配置项设置不同的AOF策略: always(每次写操作都记录)、 everysec(每秒记录一次)、 no(不记录)。
    • 优点是可以实现更高的数据实时性,适合对数据安全性要求较高的场景。
    • 缺点是AOF文件相对较大,恢复速度可能较慢。

在实际应用中,可以根据业务需求选择合适的持久化机制,甚至可以同时使用RDB和AOF,以提高数据的安全性和可靠性。另外,Redis还提供了混合持久化的方式(默认使用AOF来恢复数据,而RDB用于备份),以充分发挥两种持久化机制的优势。

Redis应用场景有哪些?

  1. 缓存: 最常见的用途,将热门数据存储在内存中,以提高访问速度,减轻数据库负担。适用于读取频繁、数据量较大的场景。

  2. 会话存储: 将用户会话数据存储在Redis中,实现分布式会话管理,以避免单点故障和状态共享问题。

  3. 计数器和统计: Redis的原子操作可以实现计数器功能,用于统计页面访问、点赞、评论等。

  4. 排行榜/热门内容: 利用有序集合(Sorted Set)数据结构,存储并排名用户、文章、商品等,以实现排行榜或展示热门内容。

  5. 发布订阅: Redis的发布订阅机制允许实时地将消息发布给订阅者,用于构建实时通知、聊天室等功能。

  6. 分布式锁: 利用Redis的原子操作和过期时间设置,实现分布式环境下的锁机制,保障资源的互斥访问。

  7. 限流器: 利用Redis的令牌桶或漏桶算法,实现请求的限流控制,防止突发流量影响系统稳定性。

  8. 缓存穿透防护: 将空值或异常数据存储在缓存中,避免缓存穿透引起的数据库查询压力。

  9. 地理位置服务: 利用Redis的地理位置数据类型,存储并查询地理位置信息,用于附近的人、地点等功能。

  10. 任务队列: 利用列表数据结构,实现异步任务队列,处理后台任务、消息队列等。

  11. 即时数据分析: 将实时产生的数据存储在Redis中,供数据分析使用,如实时监控、实时报表等。

这些只是Redis应用场景的一部分,实际上,由于Redis的高性能、低延迟和丰富的数据结构,它在很多领域都有广泛的应用。根据具体的业务需求,可以灵活选择合适的场景来使用Redis。

Redis为什么这么快?

Redis之所以具有如此高的性能,主要是由于以下几个方面的设计和优化:

  1. 内存存储: Redis将数据存储在内存中,内存的读写速度远高于磁盘,因此能够实现极低的读写延迟。

  2. 单线程模型: Redis采用单线程模型处理客户端请求,避免了多线程的锁竞争和上下文切换开销,减少了性能损耗。

  3. 非阻塞IO: Redis使用非阻塞IO和事件驱动的方式来处理客户端连接和网络通信,有效利用了操作系统提供的异步IO机制,提高了并发能力。

  4. 数据结构优化: Redis内置了多种高效的数据结构,如哈希表、有序集合、跳表等,针对不同的应用场景选择最合适的数据结构,提高了数据操作的效率。

  5. 持久化策略: Redis支持多种持久化方式,如RDB快照和AOF日志,可以根据需求选择合适的持久化策略,保障数据的可靠性。

  6. 多种网络协议支持: Redis支持多种网络协议,如HTTP、RESP(Redis Serialization Protocol)等,方便不同编程语言和应用程序与Redis进行交互。

  7. 数据压缩: Redis在存储数据时进行了压缩,减小了内存占用,提高了数据的存储密度。

  8. 预分配内存: Redis在启动时预先分配一定数量的内存,减少了内存分配的开销,提高了内存使用效率。

  9. 管道技术: Redis的管道(Pipeline)技术允许客户端发送多个命令,在一个连接上连续执行,减少了网络通信的开销。

  10. 高效的排序算法: 在有序集合(Sorted Set)中,Redis采用跳表(Skip List)作为底层数据结构,实现了高效的排序和检索。

Redis事务如何实现?

Redis事务是一组命令的集合,可以在一个原子操作内执行多个命令。Redis的事务通过MULTI、EXEC、WATCH、DISCARD等命令来实现,它提供了类似于传统数据库的事务特性,但与传统数据库的事务有一些不同之处。

以下是Redis事务的实现流程:

  1. MULTI命令: 事务开始时,客户端发送MULTI命令,告诉Redis开始记录后续的命令序列。

  2. 多个命令: 在MULTI和EXEC之间的命令会被加入到事务队列中,但并不会立即执行。

  3. EXEC命令: 当客户端发送EXEC命令时,Redis会依次执行事务队列中的命令。在执行过程中,Redis会将事务队列中的命令依次执行,如果其中的某个命令执行失败,不会影响其他命令的执行。

  4. 事务执行结果: EXEC命令执行完成后,Redis会返回事务中所有命令的执行结果,以数组形式返回。如果事务中的某个命令执行失败,对应的结果将是错误信息。

  5. DISCARD命令: 如果在MULTI和EXEC之间,客户端发送了DISCARD命令,那么事务队列中的所有命令都会被清除,事务被取消。

  6. WATCH命令: 为了实现乐观锁的机制,可以使用WATCH命令监视一个或多个键。如果在事务执行前,有其他客户端修改了被监视的键,整个事务会被取消。

Redis事务的特点:

  • Redis事务是原子性的:在EXEC执行期间,事务中的所有命令要么都被执行,要么都不被执行。
  • Redis事务是隔离的:事务的执行过程不会受到其他客户端的影响。
  • Redis事务是不支持回滚的:即使其中某个命令执行失败,不会回滚前面已经执行的命令。

需要注意的是,虽然Redis事务提供了一种封装多个命令的方式,但是由于Redis的单线程模型,事务中的某些命令可能会因为特定的情况(如阻塞操作)导致整个事务执行的时间较长。因此,在使用Redis事务时,需要考虑事务执行期间可能的性能影响。

Redis过期键删除策略?

在Redis中,有两种主要的过期键删除策略,分别是惰性删除和定期删除,还有一些淘汰策略用于释放内存空间。以下是这些策略的详细说明:

  1. 惰性删除(Lazy Expiration): 这是Redis默认的过期键删除策略。当访问一个已经过期的键时,Redis会立即删除该键并返回空值。这种策略避免了在访问时才删除键,节省了内存和CPU资源。

  2. 定期删除(定时任务删除): Redis会随机抽取一些过期键,并检查它们是否过期。如果过期,就会删除这些键。这种策略通过定期任务进行删除,以避免删除大量过期键对性能造成影响。

  3. 内存淘汰策略(Eviction Policies): 当内存使用达到一定阈值(由maxmemory参数指定)时,Redis会触发淘汰策略来释放空间。常见的淘汰策略包括:

    • noeviction:当内存不足以容纳新写入数据时,写入操作会报错。
    • allkeys-lru:从所有键中选择最近最少使用的键进行删除。
    • volatile-lru:从设置了过期时间的键中选择最近最少使用的键进行删除。
    • allkeys-random:随机选择一个键进行删除。
    • volatile-random:从设置了过期时间的键中随机选择一个键进行删除。
    • volatile-ttl:从设置了过期时间的键中选择剩余时间最短的键进行删除。

这些策略可以通过Redis的配置参数进行设置,例如:

# 设置过期键删除策略为定期删除
config set maxmemory-policy noeviction

需要根据实际场景和需求来选择适合的策略和参数值,以平衡内存使用和性能。

Redis怎么实现消息队列?

Redis可以用作轻量级的消息队列,实现基本的消息发布和订阅功能。以下是在Redis中如何实现消息队列的基本步骤:

  1. 发布消息: 在发布者端,使用PUBLISH命令将消息发布到指定的频道(通道)。

    PUBLISH channel_name message_content
  2. 订阅消息: 在订阅者端,使用SUBSCRIBE命令订阅一个或多个频道,从中接收发布者发布的消息。

    SUBSCRIBE channel_name
  3. 接收消息: 订阅者在订阅了频道后,会实时接收到发布者发布的消息。

通过上述步骤,你可以实现基本的发布-订阅模式的消息队列。然而,需要注意以下几点:

  • Redis的消息队列不支持消息持久化,即如果没有订阅者在线时,消息会丢失。
  • 如果需要支持持久化、多个消费者、消息确认等高级特性,可能需要考虑使用专门的消息队列中间件,如RabbitMQ、Apache Kafka等。

在实际应用中,如果需要更多的消息队列特性,可以使用Redis的LIST数据结构来实现简单的队列。将发布者发布的消息插入到LIST中,然后消费者从LIST中弹出消息进行处理。但需要注意的是,Redis并不是专门为消息队列设计的,更适合用于一些简单的消息发布-订阅场景。对于高性能、大规模的消息队列需求,建议使用专门的消息队列中间件。

本文由 mdnice 多平台发布

相关文章:

【面试题系列】(一)

Redis有哪些数据结构?其底层是怎么实现的? Redis 系列(一):深入了解 Redis 数据类型和底层数据结构 字符串(String): 用于存储文本或二进制数据。可以执行字符串的基本操作&#xf…...

vscode C++17便捷配置教程(懒人版)

环境链接 以上是已经配置好的c17环境链接,直接下载解压即可(注意文件路径上不要带有中文) 下载解压之后按照msys64-mingw64-bin路径打开 然后单击该路径右方空白区域可直接复制路径 然后点击开始菜单搜索“环境变量“并打开(如…...

动态数组实现链地址法哈希表

通常情况下哈希函数的输入空间远大于输出空间,因此理论上哈希冲突是不可避免的。比如,输入空间为全体整数,输出空间为数组容量大小,则必然有多个整数映射至同一数组索引。 解决哈希冲突方法常见有:链地址法、开放寻址…...

Eclipse(STS):pom.xml 报错:Multiple markers at this line

pom.xml 报错:Multiple markers at this line STS中,项目能够正常运行,但是 pom.xml 报错:Multiple markers at this line 项目本身没有任何修改,之前不报错的,突然报错了。 Multiple markers at this li…...

CSerialPort教程4.3.x (3) - CSerialPort在MFC中的使用

CSerialPort教程4.3.x (3) - CSerialPort在MFC中的使用 环境: 系统:windows 10 64位 编译器:Visual Studio 2008前言 CSerialPort项目是一个基于C/C的轻量级开源跨平台串口类库,可以轻松实现跨平台多操作系统的串口读写&#x…...

2022版 的IDEA创建一个maven项目(超详细)

一.设置idea中指定的maven的位置以及本地存储仓库 开发中一般我们使用自己下载的maven,不使用IDEA工具自带的,这就需要将我们下载的maven配置到IDEA工具中,配置如下图所示: 或者直接 快捷键 CtrlAltS 直接进入设置 maven home pa…...

lvs实现DR模型搭建

目录 一,实现DR模型搭建 1, 负载调度器配置 1.1调整ARP参数 1.2 配置虚拟IP地址重启网卡 1.3 安装ipvsadm 1.4 加载ip_vs模块 1.5 启动ipvsadm服务 1.6 配置负载分配策略 1.7 保存策略 2, web节点配置 1.1 调整ARP参数 1.2 配置虚拟I…...

设计模式之迭代器模式(Iterator)的C++实现

1、迭代器模式的提出 在软件开发过程中,操作的集合对象内部结构常常变化,在访问这些对象元素的同时,也要保证对象内部的封装性。迭代器模式提供了一种利用面向对象的遍历方法来遍历对象元素。迭代器模式通过抽象一个迭代器类,不同…...

【0基础入门Python Web笔记】二、python 之逻辑运算和制流程语句

二、python 之逻辑运算和制流程语句 逻辑运算控制流程语句条件语句(if语句)循环结构(for循环、while循环)continue、break和pass关键字控制流程语句的嵌套以及elif 更多实战项目可进入下方官网 逻辑运算 Python提供基本的逻辑运算…...

容器——Docker

1.安装docker服务,配置镜像加速器 2.下载系统镜像(Ubuntu、 centos) 3.基于下载的镜像创建两个容器 (容器名一个为自己名字全拼,一个为首名字字母) 4.容器的启动、 停止及重启操作 5.怎么查看正在运行的容器…...

SQL注入之宽字节注入

文章目录 宽字节注入是什么?注入练习让转义符失效联合查询 代码审计 宽字节注入是什么? 宽字节注入准确来说不是注入手法,而是另外一种比较特殊的情况。宽字节注入的目的是绕过单双引号转义。 宽字节注入是一种绕过单双引号转义的手段&#x…...

MyBatis动态sql

文章目录 一、MyBatis动态sql1.1 概述1.2 if元素1.3 foreach元素 二、模糊查询2.1 使用#{字段名}2.2 使用${字段名}2.3 使用concat{%,#{字段名},%}2.4 mybatis中#与$的区别 三、MyBatis结果映射3.1 区别3.2 应用场景 一、MyBatis动态sql 1.1 概述 MyBatis是一个Java持久化框架…...

L1-032 Left-pad 测试点全过

题目 根据新浪微博上的消息,有一位开发者不满NPM(Node Package Manager)的做法,收回了自己的开源代码,其中包括一个叫left-pad的模块,就是这个模块把javascript里面的React/Babel干瘫痪了。这是个什么样的…...

ssm+Vue.js在线购物系统源码和论文

ssmVue.js在线购物系统源码和论文049 开发工具:idea 数据库mysql5.7 数据库链接工具:navcat,小海豚等 技术:ssm 摘 要 随着科学技术的飞速发展,各行各业都在努力与现代先进技术接轨,通过科技手段提高自身的优势…...

港联证券|指数或进入磨底阶段 短期关注环保、煤炭等板块

磨底历来都不是一天能达到的,比方2018年的政策底到商场底,半途也阅历两个多月时间。当下政策底出现之后至今也有近一个月时间,并且下跌量能不断缩短,心情面也降至冰点,种种迹象阐明离真正商场底的构成已经不远了。此时…...

pytorch 实现VGG

VGG全称是Visual Geometry Group,因为是由Oxford的Visual Geometry Group提出的。AlexNet问世之后,很多学者通过改进AlexNet的网络结构来提高自己的准确率,主要有两个方向:小卷积核和多尺度。而VGG的作者们则选择了另外一个方向&a…...

科技项目验收检测报告获取有哪些注意事项,作用都有哪些?

验收测试报告 软件从研发到结束是一个很长的周期,对于软件想要完成上市或者是交付到用户手中之前我们还需要进行一次全面检测,也就是科技项目验收测试,此测试有着严格的要求,需要第三方软件测评机构来完成,并出具科技…...

OceanBase:谁动了我得参数?

作者:郑增权 爱可生南区数据库工程师,爱可生 DBA 团队成员,负责数据库相关技术支持。爱好:桌球、羽毛球、咖啡、电影。 本文来源:原创投稿 爱可生开源社区出品,原创内容未经授权不得随意使用,转…...

Python快速入门体验

Python快速入门体验 一、环境信息1.1 硬件信息1.2 软件信息 二、Conda安装2.1 Conda介绍2.1.1 Conda简介2.1.2 Conda、Anaconda及Miniconda及的关系 2.2 Conda安装包下载2.2.1 Miniconda下载2.2.2 Anconda下载 2.3 Conda安装2.3.1 Miniconda安装2.3.2 Anconda安装 2.4 Conda初始…...

【从零学习python 】68. Python正则表达式中的贪婪和非贪婪模式

文章目录 贪婪和非贪婪模式进阶案例 贪婪和非贪婪模式 Python里数量词默认是贪婪的(在少数语言里也可能是默认非贪婪),总是尝试匹配尽可能多的字符; 非贪婪则相反,总是尝试匹配尽可能少的字符。 在*、?、、{m,n}后面…...

MongoDB【CRUD练习-条件查询-文档关系】

练习1-CRUD // 进入test数据库 use test; // 查询文档内容 db.students.find(); // 显示当前数据库中所有集合 show collections; // 向数据库的user集合中插入一个文档 db.users.insertOne({username: "lyh"} ); // 查看当前数据库中所有的集合 发现users集合被创建…...

使用M2Mqtt 接受以及发布MQTT消息

在NuGet库里面直接查找M2Mqtt就可以安装库。 使用framework4.5.2 1.配置文件操作 public static class GModel{public static BassSetup MainSetup { get; set; }public static void GetThisAdd(){MainSetup new BassSetup();string IPAdd ConfigurationManager.AppSettings…...

【SA8295P 源码分析】33 - Android GVM USB 透传配置

【SA8295P 源码分析】33 - Android GVM USB 透传配置 1. QNX 侧配置 USB1 为 GVM 使用2. Android 端配置 dts:以配置 USB1 为例3. QNX 端配置 linux-la.config:以配置 USB1 为例4. 在Android shell 中配置USB0 / USB1 的 Host/device 模式切换系列文章汇总见:《【SA8295P 源…...

华为OD机试 - 过滤组合字符串 - 深度优先搜索dfs算法(Java 2023 B卷 100分)

目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路五、Java算法源码六、效果展示1、输入2、输出3、说明 华为OD机试 2023B卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试(JAVA)真题(A卷B卷&#…...

【Unity自制手册】游戏基础API大全

👨‍💻个人主页:元宇宙-秩沅 👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 秩沅 原创 👨‍💻 收录于专栏:Uni…...

【LVS】4、HAProxy搭建web集群

目前常见的Web集群调度器分为软件和硬件 软件通常使用开源的LVS、Haproxy、Nginx LVS性能最好(基于内核转发),但是搭建相对复杂;Nginx的upstream模块支持群集功能,但是对群集节点健康检查功能不强,高并发性…...

【应用层】网络基础 -- HTTP协议

再谈协议HTTP协议认识URLurlencode和urldecodeHTTP协议格式HTTP的方法HTTP的状态码HTTP常见HeaderHTTP周边会话保持 再谈协议 协议是一种 “约定”. socket api的接口,在读写数据时,都是按 “字符串” 的方式来发送接收的(tcp是以字节流的方式发送的&am…...

【线性DP】模型总结(terse版)

【线性DP】模型总结 最长上升子序列 DP法 ​ dp[i]表示以i结尾的最长上升子序列的长度。 ​ 对于每个i&#xff0c;遍历j1~i-1,若a[j] < a[i], 则dp[i] max(dp[i], dp[j] 1); 二分法 ​ 可以优化时间复杂度。 ​ dp[]数组用来存储当前最长上升子序列。 ​ 若dp[]数…...

conda 常用命令

conda 常用命令 一、创建环境二、删除环境三、环境重命名四 、查看环境列表五、进入某个虚拟环境六、退出当前环境七、查看当前虚拟环境下的所有安装包八、安装或卸载包(进入虚拟环境之后&#xff09;九、分享虚拟环境十、源服务器管理十一、升级十二、卸载十三、卸载十四、pip…...

前端面试:【异步编程】Callback、Promise和Async/Await

嗨&#xff0c;亲爱的JavaScript探险家&#xff01;在JavaScript开发的旅程中&#xff0c;你会经常遇到异步编程的需求。为了处理异步操作&#xff0c;JavaScript提供了多种机制&#xff0c;包括Callbacks、Promises和Async/Await。本文将深入介绍这些机制&#xff0c;让你能够…...

大数据(四):Pandas的基础应用详解

专栏介绍 结合自身经验和内部资料总结的Python教程&#xff0c;每天3-5章&#xff0c;最短1个月就能全方位的完成Python的学习并进行实战开发&#xff0c;学完了定能成为大佬&#xff01;加油吧&#xff01;卷起来&#xff01; 全部文章请访问专栏&#xff1a;《Python全栈教…...

计算机网络第3章(数据链路层)

计算机网络第3章&#xff08;数据链路层&#xff09; 3.1 数据链路层概述3.1.1 概述3.1.2 数据链路层使用的信道3.1.3 三个重要问题 3.2 封装成帧3.2.1 介绍3.2.2 透明传输3.2.3 总结 3.3 差错检测3.3.1 介绍3.3.2 奇偶校验3.3.3 循环冗余校验CRC(Cyclic Redundancy Check)3.3.…...

stm32之4.时钟体系

3.时钟体系(给单片机提供一个非常稳定的频率信号) ①可以使用三种不同的时钟源来驱动系统时钟&#xff08;SYSCLK&#xff09;&#xff0c;CPU运行的频率为168MHZ&#xff1b; HSI(RC振荡器时钟&#xff0c;也就是高速内部时钟&#xff0c;一般来说很少用&#xff0c;因为精度…...

RPC和HTTP协议

RPC 全称&#xff08;Remote Procedure Call&#xff09;&#xff0c;它是一种针对跨进程或者跨网络节点的应用之间的远程过程调用协议。 它的核心目标是&#xff0c;让开发人员在进行远程方法调用的时候&#xff0c;就像调用本地方法一样&#xff0c;不需要额外为了完成这个交…...

BUGFix:onnx -> TensorRT转换过程失败

先附上相关的onnx2trt的部分代码&#xff1a; def onnx2trt(onnx_path):logger trt.Logger(trt.Logger.ERROR)builder trt.Builder(logger)network builder.create_network(1 << int(trt.NetworkDefinitionCreationFlag.EXPLICIT_BATCH))parser trt.OnnxParser(netw…...

FFMPEG小白常用命令行

序列帧转H264视频 ffmpeg -r 60 -f image2 -s 1920x1080 -i fram%d.jpg -vcodec libx264 -crf 25 -pix_fmt yuv420p test.mp4 -vcodec h264 .\ffmpeg -r 60 -f image2 -s 1920x1080 -i %04d.jpeg -vcodec h264 test.mp4 %04d 表示用零来填充直到长度为4&#xff0c;i.e 000…...

个性定制还是纯粹简约:探寻界面选择背后的心理宇宙

在数码世界中&#xff0c;我们的界面选择成为了一张架起的桥梁&#xff0c;连接着个性的渴望与效率的追求。当我们面对个性化定制界面和极简版原装界面&#xff0c;我们仿佛站在了一座分岔路口&#xff0c;左右各有一片令人心驰神往的风景。究竟是走向五光十色的个性世界&#…...

【Java 高阶】一文精通 Spring MVC - 转发重定向(四)

&#x1f449;博主介绍&#xff1a; 博主从事应用安全和大数据领域&#xff0c;有8年研发经验&#xff0c;5年面试官经验&#xff0c;Java技术专家&#xff0c;WEB架构师&#xff0c;阿里云专家博主&#xff0c;华为云云享专家&#xff0c;51CTO 专家博主 ⛪️ 个人社区&#x…...

嵌入式Linux开发实操(十):ADC接口开发

#前言 ADC就是模数转换,可以用来接一些模拟量设备,所谓模拟量就是波形不是方波而是各种包络形状的波形的信号,比如电压、电流等电信号或压力、温度、湿度、位移、声音等非电信号,ADC就是将这些信号转换为数字方波信号,以便于信息传递的。 #ADC硬件设计 key按键连接了AD…...

精进语言模型:探索LLM Training微调与奖励模型技术的新途径

大语言模型训练&#xff08;LLM Training&#xff09; LLMs Trainer 是一个旨在帮助人们从零开始训练大模型的仓库&#xff0c;该仓库最早参考自 Open-Llama&#xff0c;并在其基础上进行扩充。 有关 LLM 训练流程的更多细节可以参考 【LLM】从零开始训练大模型。 使用仓库之…...

数据采集:selenium 提取 Cookie 自动登陆

写在前面 工作需要&#xff0c;简单整理博文内容涉及 通过 selenium 实现自动登陆理解不足小伙伴帮忙指正 对每个人而言&#xff0c;真正的职责只有一个&#xff1a;找到自我。然后在心中坚守其一生&#xff0c;全心全意&#xff0c;永不停息。所有其它的路都是不完整的&#x…...

[Go版]算法通关村第十三关黄金——数字数学问题之数论问题(最大公约数、素数、埃氏筛、丑数)

目录 题目&#xff1a;辗转相除法&#xff08;求最大公约数&#xff09;思路分析&#xff1a;辗转相除法&#xff08;也叫欧几里得算法&#xff09;gcd(a,b) gcd(b,a mod b)复杂度&#xff1a;时间复杂度 O ( n l o g ( m a x ) ) O(nlog(max)) O(nlog(max))、空间复杂度 O (…...

Qt双击某一文件通过自己实现的程序打开,并加载文件显示

双击启动 简述方法一方法二注意 简述 在Windows系统中&#xff0c;双击某类扩展名的文件&#xff0c;通过自己实现的程序打开文件&#xff0c;并正确加载及显示文件。有两种方式可以到达这个目的。 对于系统不知道的扩展名的文件&#xff0c;第一次打开时&#xff0c;需要自行…...

硬件产品的量产问题------硬件工程师在产线关注什么

前言&#xff1a; 产品开发测试无误&#xff0c;但量产缺遇到很多不良甚至DOA问题。 硬件开发过程中如何确保产线的治具、生产及硬件工程师在产线需要关注一些什么。 坚信&#xff1a;好的产品是要可以做出来的。 1、禁忌&#xff1a; 禁忌热插拔&#xff1b;禁忌测试不防呆…...

Vulnhub系列靶机--- Hackadmeic.RTB1

系列&#xff1a;Hackademic&#xff08;此系列共2台&#xff09; 难度&#xff1a;初级 信息收集 主机发现 netdiscover -r 192.168.80.0/24端口扫描 nmap -A -p- 192.168.80.143访问80端口 使用指纹识别插件查看是WordPress 根据首页显示的内容&#xff0c;点击target 点击…...

redis高级----------主从复制

redis的四种模式&#xff1a;单例模式&#xff1b;主从模式&#xff1b;哨兵模式&#xff0c;集群模式 一、主从模式 单例模式虽然操作简单&#xff0c;但是不具备高可用 缺点&#xff1a; 单点的宕机引来的服务的灾难、数据丢失单点服务器内存瓶颈&#xff0c;无法无限纵向扩…...

posgresql通过PL/pgSQL脚本统一修改某字段大小写

项目在做postgresql数据库适配时遇到了某些问题&#xff0c;需要统一将某个模式含id字段的全部表&#xff0c;将id字段由小写转换为大写&#xff0c;可以通过PL/pgSQL脚本实现。 先确保当前用户有足够的权限 DO $$ DECLARE current_table text;current_column text; BEGIN --…...

iPhone卫星通信SOS功能如何在灾难中拯救生命

iPhone上的卫星紧急求救信号功能在从毛伊岛野火中拯救一家人方面发挥了至关重要的作用。这是越来越多的事件的一部分&#xff0c;在这些事件中&#xff0c;iPhone正在帮助人们摆脱危及生命的情况。 卫星提供商国际通信卫星组织负责移动的高级副总裁Mark Rasmussen在接受Lifewir…...

NOIP真题答案 过河 数的划分

过河 题目描述 在河上有一座独木桥&#xff0c;一只青蛙想沿着独木桥从河的一侧跳到另一侧。在桥上有一些石子&#xff0c;青蛙很讨厌踩在这些石子上。由于桥的长度和青蛙一次跳过的距离都是正整数&#xff0c;我们可以把独木桥上青蛙可能到达的点看成数轴上的一串整点&#xf…...

图为科技-边缘计算在智慧医疗领域的作用

边缘计算在智慧医疗领域的作用 随着科技的进步&#xff0c;智慧医疗已成为医疗行业的重要发展趋势。边缘计算作为新兴技术&#xff0c;在智慧医疗领域发挥着越来越重要的作用。本文将介绍边缘计算在智慧医疗领域的应用及其优势&#xff0c;并探讨未来发展方向。 一、边缘计算…...