项目场景拷打
补偿事务解决超卖
通过补偿事务避免超卖问题,可以通过以下几种方式实现:
1. 使用数据库事务与锁机制
-
事务管理:将库存扣减和订单生成操作放在同一个数据库事务中,确保操作的原子性。如果事务中任何一个步骤失败,则整个事务回滚,避免超卖。
-
悲观锁:在更新库存时,使用数据库的悲观锁(如
SELECT ... FOR UPDATE
),确保同一时间只有一个事务可以修改库存记录。 -
乐观锁:通过在数据库表中增加版本号字段,每次更新库存时检查版本号是否一致。如果不一致,则放弃操作。
2. 使用分布式锁和补偿机制
-
分布式锁:在高并发场景下,可以使用分布式锁(如基于 Redis 的锁)来控制并发访问,确保同一时间只有一个请求可以操作库存。
-
补偿机制:在操作过程中,如果某个步骤失败,可以通过补偿机制来恢复库存。例如,如果 Redis 操作成功但数据库操作失败,则对 Redis 进行逆向补偿,并记录补偿日志,异步重试。
3. 异步补偿与延迟任务
-
延迟任务:对于超时未支付的订单,使用延迟消息或定时任务关闭订单,并对库存进行补偿。
-
异步补偿:在分布式系统中,如果某个服务的操作失败,可以通过异步补偿机制(如消息队列)来恢复数据一致性。
4. 优化操作顺序
-
扣减库存顺序:在扣减库存时,先扣减 Redis 中的库存,再扣减数据库中的库存。如果 Redis 操作成功但数据库操作失败,则进行补偿。
-
增加库存顺序:在增加库存时,先增加数据库中的库存,再增加 Redis 中的库存。
通过上述方法,可以有效避免超卖问题,同时确保系统的高并发处理能力和数据一致性。
优化后端架构,通过分布式缓存(如 Redis)和负载均衡技术(如 Nginx),成功应对每秒数千次的并发 请求,确保系统在高流量下稳定运行。
优化后端架构以应对高并发请求是一个复杂但非常重要的任务,尤其是在面对每秒数千次的并发请求时。通过使用分布式缓存(如Redis)和负载均衡技术(如Nginx),可以有效提升系统的性能和稳定性。以下是具体的优化方案和实施步骤:
1. 使用分布式缓存(Redis)
分布式缓存是解决高并发问题的关键技术之一,它可以减轻数据库的压力,提高系统的读取速度。
1.1 缓存策略
-
热点数据缓存:将频繁访问的数据(如用户信息、配置信息等)存储在Redis中。
-
缓存失效策略:合理设置缓存的过期时间(TTL),避免缓存穿透和缓存雪崩。
-
缓存穿透:通过在应用层进行校验,避免查询不存在的数据。
-
缓存雪崩:通过设置不同的过期时间或使用持久化机制(如RDB或AOF)来缓解。
-
-
分布式锁:在高并发场景下,使用Redis的分布式锁来避免数据竞争。
1.2 Redis集群
-
水平扩展:使用Redis集群模式,通过分片将数据分散到多个节点,提高缓存容量和读写性能。
-
高可用性:配置主从复制和哨兵机制,确保在某个节点故障时可以快速切换。
1.3 性能优化
-
连接池:使用连接池管理Redis连接,减少连接创建和销毁的开销。
-
批量操作:通过Redis的批量操作(如
MGET
、MSET
)减少网络请求次数。 -
压缩数据:对存储在Redis中的数据进行压缩,减少内存占用。
2. 使用负载均衡技术(Nginx)
负载均衡是确保系统在高流量下稳定运行的关键技术,Nginx是一个常用的负载均衡器。
2.1 配置Nginx
-
反向代理:将Nginx配置为反向代理服务器,将客户端请求转发到后端应用服务器。
nginx复制
server {listen 80;server_name example.com;location / {proxy_pass http://backend_servers;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;} }
-
负载均衡策略:配置负载均衡策略,如轮询、最少连接数或加权最少连接数。
nginx复制
upstream backend_servers {server backend1.example.com weight=3;server backend2.example.com weight=3;server backend3.example.com weight=2; }
2.2 高可用性
-
故障转移:配置Nginx的
fail_timeout
和max_fails
参数,确保在后端服务器故障时自动切换。nginx复制
upstream backend_servers {server backend1.example.com weight=3 max_fails=3 fail_timeout=30s;server backend2.example.com weight=3 max_fails=3 fail_timeout=30s;server backend3.example.com weight=2 max_fails=3 fail_timeout=30s; }
-
多实例部署:部署多个Nginx实例,通过DNS轮询或使用负载均衡器(如HAProxy)实现高可用性。
2.3 性能优化
-
连接复用:通过
keepalive
参数复用后端连接,减少连接开销。nginx复制
http {keepalive_timeout 65;upstream backend_servers {server backend1.example.com;server backend2.example.com;keepalive 32;} }
-
缓存静态资源:通过Nginx缓存静态资源(如图片、CSS、JS等),减少后端服务器的压力。
nginx复制
location ~* \.(jpg|jpeg|png|gif|css|js)$ {expires 30d;add_header Cache-Control "public"; }
3. 应用层优化
除了缓存和负载均衡,应用层的优化也非常重要。
3.1 数据库优化
-
读写分离:通过主从复制实现读写分离,减轻主数据库的压力。
-
索引优化:合理使用索引,提高查询性能。
-
分库分表:通过分库分表减少单表数据量,提高读写性能。
3.2 服务拆分
-
微服务架构:将系统拆分为多个微服务,每个服务独立部署和扩展。
-
异步处理:使用消息队列(如RocketMQ)处理异步任务,减轻主线程压力。
3.3 缓存穿透和雪崩
-
布隆过滤器:使用布隆过滤器快速判断数据是否存在,避免缓存穿透。
-
本地缓存:在应用层使用本地缓存(如Guava Cache)作为二级缓存,减轻Redis压力。
4. 监控与报警
-
监控指标:监控系统的关键指标,如CPU、内存、网络带宽、响应时间等。
-
日志分析:通过ELK(Elasticsearch、Logstash、Kibana)等工具分析日志,及时发现异常。
-
报警机制:配置报警机制(如Prometheus + Alertmanager),在系统异常时及时通知运维人员。
5. 测试与优化
-
压力测试:使用工具(如JMeter、Locust)进行压力测试,模拟高并发场景。
-
性能瓶颈分析:通过监控工具(如APM工具)分析性能瓶颈,针对性优化。
-
持续优化:根据实际运行情况,持续优化系统架构和配置。
总结
通过分布式缓存(Redis)和负载均衡技术(Nginx),可以有效应对每秒数千次的并发请求,确保系统在高流量下稳定运行。同时,结合应用层优化、数据库优化、服务拆分、监控报警等手段,可以进一步提升系统的性能和可靠性。
优化数据库设计,使用索引优化、分表分库策略,结合 MyBatis 持久层框架,将数据库查询响应时 间缩短至毫秒级,显著提升系统性能。
以下是一些通过索引优化、分表分库策略以及结合 MyBatis 持久层框架来优化数据库设计,从而将数据库查询响应时间缩短至毫秒级并显著提升系统性能的方法:
索引优化
-
合理创建索引:根据查询需求,为经常用于查询条件的列(如
WHERE
子句中的列、JOIN
条件中的列等)创建索引。例如,对于频繁查询的字段,可以创建普通索引或复合索引。 -
避免索引失效:注意避免一些操作导致索引失效,如在
WHERE
条件中使用函数或数据类型不匹配。 -
使用覆盖索引:创建包含所有查询所需列的索引,避免查询时回表操作,从而进一步提升查询效率。
-
定期维护索引:随着数据的变化,索引的效率可能会下降。因此,需要定期检查、优化和清理索引,删除冗余或无用的索引。
分表分库策略
-
垂直分表:将表中不常用的字段分离到新的表中,减少单表的数据量和复杂度,提高查询效率。
-
水平分表:根据业务规则将数据分散到多个表中,例如按时间、用户ID范围等进行分表。
-
分库:将不同的业务模块数据存储在不同的数据库中,减轻单个数据库的压力。
-
分布式数据库:在大规模数据场景下,可以使用分布式数据库系统,通过分片技术将数据分散到多个节点上,提升系统的扩展性和查询性能。
结合 MyBatis 持久层框架
-
优化 SQL 映射:在 MyBatis 的映射文件中,编写高效的 SQL 语句,避免全表扫描、减少
JOIN
操作,尽量指定查询所需的字段,避免使用SELECT *
。 -
使用缓存:MyBatis 提供了缓存机制,可以配置一级缓存和二级缓存。合理使用缓存可以减少对数据库的访问次数,提高系统的响应速度。
-
批量操作:在进行批量插入、更新等操作时,使用 MyBatis 的批量执行功能,减少数据库连接和交互次数。
-
分页查询优化:对于大数据量的分页查询,可以使用 MyBatis 的分页插件,或者通过优化 SQL 语句(如使用覆盖索引或 ID 方式)来提高分页查询的性能。
其他优化建议
-
数据库监控与分析:启用慢查询日志,分析执行时间长的 SQL 语句并进行优化。同时,可以使用工具(如 Prometheus + Grafana)对数据库性能进行监控。
-
读写分离:通过主从复制,将读操作和写操作分别分发到不同的数据库实例上,减轻主库的压力。
-
硬件与配置优化:确保数据库服务器的硬件资源(如 CPU、内存、磁盘 I/O)充足,并根据实际需求调整数据库的配置参数。
通过以上综合优化措施,可以有效缩短数据库查询响应时间至毫秒级,显著提升系统性能。
实现安全的支付网关集成,确保支付数据的加密传输和存储,保障用户支付安全。
实现安全的支付网关集成并确保支付数据的加密传输和存储,可以从以下几个关键方面入手:
1. 数据加密
-
传输加密:确保所有敏感数据(如信用卡号、CVV码等)在传输过程中使用SSL/TLS协议进行加密,防止数据在传输过程中被截获和篡改。
-
存储加密:对于存储的支付数据,采用高级加密标准(AES)等加密技术进行加密处理,确保数据在存储过程中的安全性。
-
端到端加密:选择支持端到端加密的支付网关,确保数据从用户端到支付处理中心的全程加密。
2. 数据标记化
采用数据标记化技术,将敏感的支付信息(如信用卡号)替换为唯一的非敏感标记(令牌)。这样可以减少敏感数据在系统中的存储和传输风险,同时降低数据泄露的可能性。
3. 验证与授权
-
多因素认证:在支付过程中,结合密码、短信验证码或生物识别等多种认证方式,提升交易的安全性。
-
签名验证:确保支付网关的回调请求通过签名验证机制,防止恶意请求。
4. 欺诈检测与预防
-
地址验证服务(AVS)和CVV验证:通过这些机制识别和阻止可疑交易。
-
风险评估工具:利用支付网关提供的风险评估工具,检测来自高风险地区的异常交易行为。
5. 合规性
-
PCI DSS标准:确保支付网关和相关系统符合支付卡行业数据安全标准(PCI DSS),这是保护支付卡数据的全球标准。
-
隐私法规:遵守GDPR等隐私保护法规,确保客户的个人信息得到妥善保护。
6. 安全审计与监控
-
定期安全审计:定期对支付系统进行安全审计,确保没有安全漏洞。
-
监控与日志记录:对支付流程进行监控,记录每次支付请求和回调的详细日志,方便后续排查问题。
7. 选择可靠的支付网关提供商
-
行业标准认证:选择符合PCI DSS等行业标准的支付网关提供商。
-
技术支持与社区支持:选择有良好技术支持和社区支持的支付网关,以便在遇到问题时能够快速获得帮助。
通过以上措施,可以有效保障支付数据的安全传输和存储,从而确保用户支付的安全性。
开发一个高效的库存管理系统,支持实时库存更新和预警机制,确保库存数据的准确性,减少因库存问题导致的订单取消率,可以从以下几个方面入手:
1. 实现实时库存更新
-
数据采集与同步:通过条形码扫描枪、RFID标签等自动化设备,快速准确地录入库存数据。同时,将库存管理系统与企业的ERP系统对接,确保库存数据与采购、销售数据实时同步。
-
系统功能支持:选择具备自动进销存功能的库存管理系统,如金蝶云·星辰进销存管理系统,能够自动记录采购入库、销售出库等操作,确保库存数据的实时性和准确性。
2. 设计预警机制
-
低库存预警:当库存量低于设定的安全库存水平时,系统自动发出预警,提醒采购部门及时补货。
-
高库存预警:当库存量超过设定的最高库存水平时,系统发出预警,提示管理人员采取措施处理过剩库存。
-
过期库存预警:对于有保质期的商品,系统根据保质期设置预警规则,避免因过期造成的损失。
-
滞销商品预警:根据销售数据,自动识别滞销商品并发出预警,提醒销售部门进行清理或促销。
-
订单与库存关联预警:当订单生成时,系统自动检查库存是否充足,避免因库存不足导致订单无法完成。
3. 确保库存数据准确性
-
数据校验与核对:系统自动进行数据校验,避免重复录入或错误输入。同时,设置权限控制,防止未经授权的人员修改库存数据。
-
定期盘点与对账:定期进行库存盘点,发现数据与实际库存的差异,并及时修正。
4. 降低订单取消率
-
实时库存更新:确保商品库存信息实时更新,避免因库存不足导致订单取消。
-
优化物流管理:选择可靠的物流服务,利用物流追踪工具实时监控订单状态,提前备货,减少因物流问题或缺货导致的订单取消。
-
提升客户服务:快速响应客户咨询,及时确认订单信息,提供完善的售后服务,提升客户满意度。
通过以上措施,可以有效开发出一个支持实时库存更新和预警机制的高效库存管理系统,确保库存数据的准确性,从而减少因库存问题导致的订单取消率。
相关文章:
项目场景拷打
补偿事务解决超卖 通过补偿事务避免超卖问题,可以通过以下几种方式实现: 1. 使用数据库事务与锁机制 事务管理:将库存扣减和订单生成操作放在同一个数据库事务中,确保操作的原子性。如果事务中任何一个步骤失败,则整…...
C语言之扫雷
C语言之扫雷 game.hgame.ctest.c 参考 https://blog.csdn.net/m0_62391199/article/details/124694375 game.h #pragma once #include <stdio.h> #include <time.h> #include <stdlib.h>#define ROW 9 #define COL 9#define ROWS ROW2 #define COLS COL2#de…...
android手机本地部署deepseek1.5B
手机本地部署大模型需要一个开源软件 Release Release v1.6.7 a-ghorbani/pocketpal-ai GitHub 下载release版本apk 它也支持ios,并且是开源的,你可以编译修改它 安装完后是这样的 可以下载推荐的模型,也可以在pc上下载好,然后copy到手机里 点 + 号加载本地模型...
用C语言实现斐波那契数列:从基础代码到深入理解
在编程的世界里,斐波那契数列是一个经典且有趣的概念,今天我们就通过一段C语言代码来深入探索如何生成斐波那契数列。 代码初览 这段代码实现了输入一个整数 n ,然后输出斐波那契数列的第 n 项。 代码逐行解析 变量声明: - int …...
vue3 怎么自动全局注册某个目录下的所有 vue 和 tsx 组件
在开发 vue3 项目时,我们会有这样的诉求,怎么自动全局注册某个目录下的所有 vue 和 tsx 组件? 虽然已经有非常强大的 unplugin-vue-components 支持,但是在某些动态场景下,unplugin-vue-components 也选择了不支持。 …...
Android 消息总站 设计思路
项目是组件化模式,这里记录下项目消息总站设计思路 目录 1、接口模式 2、Viewmodel 模式 3、LiveDataBus 模式 3、EventBus 模式 1、接口模式 消息总站:MessageCenter 单利模式 public class MessageCenter {private static MessageCenter instanc…...
webstorm 右下角git分支组件不显示如何恢复
1、在上方工具栏点击view 2、选择Appearance 3、选择 Status Bar Widgets 4、勾选Git Branch 目录如下图所示...
三、k8s pod详解
pod详解的相关的基础知识和初始化容器,以及私有化的镜像仓库*。 pod进阶:pod的状态,pod的探针 pod的详解: pod是k8s集群管理的最小单位,最小的资源组件,也是最小化运行容器的资源对象。 容器运行在pod里…...
代码随想录算法训练day39--动态规划之《打家劫舍系列》
代码随想录算法训练 —day39 文章目录 代码随想录算法训练前言一、198.打家劫舍二、213.打家劫舍II三、337.打家劫舍 III总结 前言 今天是算法训练的第39天,希望自己能够坚持下来! 今日任务依旧是动态规划,不过是打家劫舍系列: …...
AI是什么?
一、概述 1.1 AI是什么 就像给机器装了个"会学习的大脑",让它们能像人一样: 看懂世界(比如手机相册自动识别猫狗照片)听懂人话(比如叫"Siri定个闹钟")自己思考(比如围棋…...
ZooKeeper 的典型应用场景:从概念到实践
引言 在分布式系统的生态中,ZooKeeper 作为一个协调服务框架,扮演着至关重要的角色。它的设计目的是提供一个简单高效的解决方案来处理分布式系统中常见的协调问题。本文将详细探讨 ZooKeeper 的典型应用场景,包括但不限于配置管理、命名服务…...
C++ list介绍
文章目录 1. list简介2. list的实现框架2.1 链表结点2.2 链表迭代器2.3 链表 3. list迭代器及反向迭代器设计3.1 list迭代器3.2 list反向迭代器3.3 list迭代器失效 4. list与vector比较 1. list简介 list,即链表。 链表的种类有很多,是否带头结点&#…...
暂未整理啊
测码学院 python的数据类型 不可变数据类型:字符串/数字/元组/ type(变量名) 获得数据的类型 str:字符串 int:整数 float:浮点数 bool:true/false 布尔类型 list:列表 dict&…...
C# Basic
文章目录 项目地址一、基础501. What is CIL?2. What is CLR?3. What is the difference betweent value type and reference types?4. what is boxing and unboxing?5. How are exceptions handled in C#?6. What is the difference between a class and a struct?7. Wh…...
小红书爬虫: 获取所需数据
小红书,又名 “小红书 ”或简称 “红”,已迅速成为中国社交和电子商务领域的重要参与者,成为一个不可或缺的平台。对于企业、营销人员和数据分析师来说,从小红书收集数据可以获得宝贵的洞察力,从而推动业务增长。虽然这…...
人工智能学习(七)之神经网络
目录 一、引言 二、经典神经网络回顾 (一)结构与计算过程 (二)局限性 三、循环神经网络(RNN)原理 (一)基本结构 (二)计算过程 (三…...
LeetCode --- 435周赛
题目列表 3442. 奇偶频次间的最大差值 I 3443. K 次修改后的最大曼哈顿距离 3444. 使数组包含目标值倍数的最少增量 3445. 奇偶频次间的最大差值 II 一、奇偶频次间的最大差值I 统计字母出现次数,然后分别统计出现偶数次的最小值和出现奇数次的最大值,…...
算法 ST表
目录 前言 一,暴力法 二,打表法 三,ST表 四,ST表的代码实现 总结 前言 ST表的主要作用是在一个区间里面寻找最大值,具有快速查找的功能,此表有些难,读者可以借助我的文章和网上的课程结…...
【AI论文】使用滑动磁贴注意力实现快速视频生成
摘要:扩散变换器(DiTs)凭借3D全局注意力机制在视频生成领域达到了最先进水平,但其计算成本高昂——生成一段仅5秒的720P视频时,仅注意力计算就占用了总推理时间的945秒中的800秒。本文引入了滑动磁贴注意力(…...
MAAS | Ollama 搭建本地 AI 大模型 deepseekWeb 界面调用
目录 一、环境准备二、安装 Ollama三、下载并部署 DeepSeek 模型四、简单交互五、通过 Web 界面调用大模型 在当今人工智能快速发展的时代,本地部署大语言模型赋予了用户更高的灵活性和个性化服务体验。本文介绍了如何准备环境、安装Ollama框架、下载并部署DeepSeek…...
Arduino 第十一章:温度传感器
Arduino 第十一章:LM35 温度传感器 一、LM35 简介 LM35 是美国国家半导体公司(现德州仪器)生产的一款精密集成电路温度传感器。与基于热力学原理的传统温度传感器不同,LM35 能直接将温度转换为电压输出,且输出电压与…...
普通用户授权docker使用权限
1、检查docker用户组 sudo cat /etc/group |grep docker 若显示:docker:x:999: # 表示存在否则创建docker用户组: sudo groupadd docker2、查看 /var/run/docker.sock 的属性 ll /var/run/docker.sock 显示: srw-rw---- 1 root root 0 1月…...
嵌入式软件C语言面试常见问题及答案解析(四)
嵌入式软件C语言面试常见问题及答案解析(四) 原本打算将链表相关的面试题整合到一个文档中,奈何写着写着就发现题目比较多,题型也比较丰富,所以导致上一篇已经足够长了,再长也就有点不礼貌了。 所以在这儿继续来总结分享那个面试中遇到的题目,文中的问题和提供的答案或者…...
Python中是否有类似R语言中rds的功能,可将对象保存为文件?
在数据分析和科学计算领域,R语言和Python都是极为流行的编程语言。它们各自拥有独特的优势和丰富的库资源,使得数据科学家们能够高效地处理和分析数据。在R语言中,RDS(R Data Serialization)格式是一种非常方便的方式&…...
LabVIEW无人机飞行状态监测系统
近年来,无人机在农业植保、电力巡检、应急救灾等多个领域得到了广泛应用。然而,传统的目视操控方式仍然存在以下三大问题: 飞行姿态的感知主要依赖操作者的经验; 飞行中突发的姿态异常难以及时发现; 飞行数据缺乏系统…...
车联网安全入门一:了解CAN总线及环境模拟
准备打工了,工作内容和车联网安全相关,本来想着和app分析有较大关系,但是还涉及到很多关于汽车渗透测试相关的知识,由于之前并没有接触过,就借此机会和大家来学习一下。 ## CAN基础知识 ### CAN(Controller…...
hive spark读取hive hbase外表报错分析和解决
问题现象 使用Spark shell 操作hive关联Hbase的外表导致报错;hive使用tez引擎操作关联Hbase的外表时报错。 问题1:使用tez或spark引擎,在hive查询时只要关联hbase的hive表就会有问题其他表正常。 “org.apache.hadoop.hbase.client.RetriesExhaustedException:Can’t get …...
【MQ】RabbitMQ 高可用延时功能的探究
延迟消息如果使用延时交换机来实现,如果数据量过大,就会很占 CPU 资源,轻则时间误差大,重则 RabbitMQ 宕机 一、针对一个 RabbitMQ 节点 (1)利用队列 ttl,将延迟消息根据 delay 的时间进行分级…...
网络安全讲座之一:网络安全的重要性
第一讲内容主要对于安全的发展以及其重要性作了简明的阐述,并介绍了一些国内外知名的网络安全相关网站,并对于如何建立有效的安全策略给出了很好的建议,并让大家了解几种安全标准。 媒体经常报道一些有关网络安全威胁的令人震惊的事件&am…...
flutter ListView Item复用源码解析
Flutter 的 ListView 的 Item 复用机制是其高性能列表渲染的核心,底层实现依赖于 Flutter 的渲染管线、Element 树和 Widget 树的协调机制。以下是 ListView 复用机制的源码级解析,结合关键类和核心逻辑进行分析。 1. ListView 的底层结构 ListView 的复…...
基于java手机销售网站设计和实现(LW+源码+讲解)
专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎高校老师/同行前辈交流合作✌。 技术范围:SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:…...
HTML 左右联动高亮示例
HTML 左右联动高亮示例 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>左右联动高亮示例</titl…...
如何本地部署DeepSeek
第一步:安装ollama https://ollama.com/download 打开官网,选择对应版本 第二步:选择合适的模型 https://ollama.com/ 模型名称中的 1.5B、7B、8B 等数字代表模型的参数量(Parameters),其中 B 是英文 B…...
虚拟机+Docker配置主机代理和常见配置
完整配置流程如下: 配置虚拟机使用宿主机代理: # 设置环境变量(宿主机IP为192.168.100.1,代理端口7890) export http_proxyhttp://192.168.100.1:7890 export https_proxyhttp://192.168.100.1:7890# 测试代理是否生…...
996引擎-问题处理:盟重传送石问题
996引擎-问题处理:盟重传送石问题 问题解决方案补充:回城卷参考资料问题 今天添加了个新地图,由于这个版本只有盟重传送石没设计回城卷。 所以怎么搞都回不到新地图的回城点。(当时也是懵逼了都忘记它叫 盟重 传送石`) 分析 先看一下道具表的配置。 [@StdModeFuncX] 表示…...
从零到一学习c++(基础篇--筑基期七-vector与迭代器)
从零到一学习C(基础篇) 作者:羡鱼肘子 温馨提示1:本篇是记录我的学习经历,会有不少片面的认知,万分期待您的指正。 温馨提示2:本篇会尽量用更加通俗的语言介绍c的基础,用通俗的语言去…...
PKI及SSL协议分析
PKI的基本组成,完整的PKI系统必须具有权威认证机构(CA)、数字证书库、密钥备份及恢复系统、证书作废系统、应用接口(API)等基本构成部分,构建PKI也将围绕着这五大系统来着手构建。 任务一:搭建CA服务器 本任务初步了…...
请解释 JavaScript 中的函数式编程,优缺点是什么?
一、对JavaScript函数式编程的理解 函数式编程(Functional Programming,FP)是一种编程范式,它将计算视为数学函数的求值,并避免改变状态和可变数据。 在JavaScript中,函数式编程具有以下几个关键特性&…...
WPS接入DeepSeek模型
1.wps 下载安装 WPS-支持多人在线协作编辑Word、Excel和PPT文档_WPS官方网站 (最好是安装最新的wps) 2.offieceAi工具下载安装 软件下载 | OfficeAI助手 下载后安装下载下来的两个工具。安装路径可以自行修改 3.打开WPS,点击文件-》 选项-》信任中心 勾…...
头条百度批量采集软件说明文档
旧版说明文档《头条号文章批量采集软件4.0版本说明文档!头条/微头条文章批量采集》 头条的采集软件已经更新了好多个版本了,一直没有做详细的介绍文档,最近更新了一些功能进去,一块来写一下说明文档。 1、主界面 2、头条作者采集…...
网络安全架构师怎么考 网络安全 架构
安全通信网络 随着现代技术的不断发展,等级保护对象通常通过网络实现资源共享和数据交互,当大量的设备连成网络后,网络安全成了最为关注的问题。按照“一个中心,三重防御”的纵深防御思想,边界外部通过广域网或城域网…...
Vue 3 30天精进之旅:Day 21 - 项目实践:打造功能完备的Todo应用
前言 经过前20天的学习,我们已经掌握了Vue 3的核心概念、组合式API、路由、状态管理等关键技术。今天将通过一个完整的项目实践——Todo应用,将所学知识融会贯通。我们将为Todo应用添加编辑、删除、过滤等进阶功能,并优化代码结构。 一、项目…...
2025年02月11日Github流行趋势
项目名称:unsloth 项目地址url:https://github.com/unslothai/unsloth项目语言:Python历史star数:27175今日star数:1024项目维护者:danielhanchen, shimmyshimmer, Erland366, Datta0, xyangk项目简介&…...
嵌入式硬件篇---原码、补码、反码
文章目录 前言简介八进制原码、反码、补码1. 原码规则示例问题 2. 反码规则示例问题 3. 补码规则示例优点 4. 补码的运算5. 总结 十六进制原码、反码、补码1. 十六进制的基本概念2. 十六进制的原码规则示例 3. 十六进制的反码规则示例 4. 十六进制的补码规则示例 5. 十六进制补…...
PCM与G711A互转
PCM与G711A互转 工具类(Java)调用方法(Kotlin) 工具类(Java) public class G711Code {private final static int SIGN_BIT 0x80;private final static int QUANT_MASK 0xf;private final static int SEG…...
MapReduce简单应用(三)——高级WordCount
目录 1. 高级WordCount1.1 IntWritable降序排列1.2 输入输出格式1.3 处理流程 2. 代码和结果2.1 pom.xml中依赖配置2.2 工具类util2.3 高级WordCount2.4 结果 参考 本文引用的Apache Hadoop源代码基于Apache许可证 2.0,详情请参阅 Apache许可证2.0。 1. 高级WordCo…...
C# 数据验证Regex
Regular Expression,简称 Regex,是一种用于匹配和处理文本的强大工具。它通过定义特定的模式,可以用来搜索、替换或提取字符串中的特定内容。 先引入命名空间 using System.Text.RegularExpressions; Intege(整数) 必须是正整数 //必须是正整数publi…...
Jenkins+gitee 搭建自动化部署
Jenkinsgitee 搭建自动化部署 环境说明: 软件版本备注CentOS8.5.2111JDK1.8.0_211Maven3.8.8git2.27.0Jenkins2.319最好选稳定版本,不然安装插件有点麻烦 一、安装Jenkins程序 1、到官网下载相应的版本war或者直接使用yum安装 Jenkins官网下载 直接…...
C/C++混合读入cin与scanf问题
因为C/C在某些时候是如此的融洽,以至于很多时候可能会混用,就比如 scanf与cin或getline(cin, ..)这是一个严肃的问题。因为随意混用,可能导致,在某些特殊时刻,读取混乱。所以本篇的意义就是为了缕清混用机制 一、scan…...
矩阵 NFC 碰一碰发视频源码搭建技术解析,支持OEM
一、引言 在移动互联与物联网飞速发展的当下,NFC(Near Field Communication,近场通信)技术凭借其便捷、快速的数据传输特性,在众多领域得到广泛应用。本文将深入探讨如何搭建矩阵 NFC 碰一碰发视频的源码,…...