Java 性能优化:从原理到实践的全面指南
性能优化是 Java 开发中不可或缺的一环,尤其在高并发、大数据和分布式系统场景下,优化直接影响系统响应速度、资源利用率和用户体验。Java 作为一门成熟的语言,提供了丰富的工具和机制支持性能调优,但优化需要深入理解 JVM、并发模型和代码设计。本文将系统探讨 Java 性能优化的核心原理,覆盖内存管理、并发处理、IO 操作和代码层面的优化策略,并结合 Java 代码实现一个高性能的任务处理系统。
一、Java 性能优化的核心领域
1. 什么是性能优化?
性能优化是指通过调整代码、配置或架构,减少系统资源消耗(如 CPU、内存、IO),提升响应速度和吞吐量的过程。在 Java 中,优化通常聚焦以下方面:
- 内存管理:减少垃圾回收(GC)开销,优化对象分配。
- 并发性能:提高线程效率,降低锁竞争。
- IO 效率:优化文件、网络和数据库操作。
- 代码执行:消除冗余计算,改进算法。
2. 为什么需要性能优化?
- 用户体验:低延迟和高吞吐提升满意度。
- 资源成本:减少服务器和云服务费用。
- 系统稳定性:避免高负载下的崩溃。
- 扩展性:支持更大的用户规模。
3. 优化的挑战
- 权衡:性能提升可能增加代码复杂性。
- 环境依赖:不同 JVM 和硬件表现不一。
- 诊断难度:定位瓶颈需专业工具。
二、Java 性能优化的核心策略
以下从内存、并发、IO 和代码四个维度分析优化策略。
1. 内存管理优化
原理
- JVM 内存模型:
- 堆:存储对象,分为年轻代(Eden、Survivor)和老年代。
- 非堆:方法区、常量池。
- 垃圾回收:
- 年轻代:Minor GC,回收短生命周期对象。
- 老年代:Major GC,回收长生命周期对象。
- 瓶颈:
- 频繁 GC 导致停顿(Stop-The-World)。
- 大对象分配耗时。
- 内存泄漏。
优化策略
- 减少对象分配:
- 重用对象,减少临时对象。
- 使用基本类型而非包装类。
- 优化 GC:
- 选择合适的 GC 算法(如 G1、ZGC)。
- 调整堆大小和代比例。
- 避免内存泄漏:
- 关闭资源(如 Stream、Connection)。
- 检查集合(如 HashMap)中的长期引用。
示例:对象池重用
public class ObjectPool<T> {private final Queue<T> pool = new LinkedList<>();private final Supplier<T> creator;public ObjectPool(Supplier<T> creator, int size) {this.creator = creator;for (int i = 0; i < size; i++) {pool.offer(creator.get());}}public T borrow() {return pool.isEmpty() ? creator.get() : pool.poll();}public void release(T obj) {pool.offer(obj);}
}
2. 并发性能优化
原理
- 线程模型:
- Java 线程基于 OS 线程,创建和切换成本高。
- 线程池复用线程,降低开销。
- 锁竞争:
- 同步(如
synchronized
)可能导致线程阻塞。 - 高并发下,锁粒度影响性能。
- 同步(如
- 瓶颈:
- 线程过多导致上下文切换。
- 锁竞争引发延迟。
优化策略
- 线程池:
- 使用
ThreadPoolExecutor
控制线程数。 - 调整核心线程、最大线程和队列大小。
- 使用
- 无锁编程:
- 使用
ConcurrentHashMap
、AtomicInteger
等。 - CAS(Compare-And-Swap)替代锁。
- 使用
- 异步处理:
- 使用
CompletableFuture
解耦任务。
- 使用
- 锁优化:
- 减小锁范围,优先读写锁(
ReentrantReadWriteLock
)。
- 减小锁范围,优先读写锁(
示例:异步任务
public CompletableFuture<String> processAsync(String input) {return CompletableFuture.supplyAsync(() -> {// 模拟耗时操作try {Thread.sleep(100);} catch (InterruptedException e) {Thread.currentThread().interrupt();}return input.toUpperCase();});
}
3. IO 优化
原理
- IO 类型:
- 文件 IO:读写磁盘。
- 网络 IO:HTTP、Socket。
- 数据库 IO:SQL 查询。
- 瓶颈:
- 阻塞 IO(如
InputStream
)导致线程等待。 - 频繁小块读写增加开销。
- 数据库查询未命中索引。
- 阻塞 IO(如
优化策略
- 缓冲区:
- 使用
BufferedInputStream
、BufferedWriter
。 - 批量读写减少系统调用。
- 使用
- 异步 IO:
- 使用 NIO(
Selector
、Channel
)。 - Netty 等框架支持高并发网络。
- 使用 NIO(
- 数据库优化:
- 添加索引,优化 SQL。
- 使用连接池(如 HikariCP)。
示例:缓冲文件读写
public void writeFile(String filePath, String data) throws IOException {try (BufferedWriter writer = new BufferedWriter(new FileWriter(filePath))) {writer.write(data);}
}
4. 代码执行优化
原理
- 热点代码:JIT(Just-In-Time)编译优化频繁执行的代码。
- 算法效率:复杂度决定执行时间。
- 冗余计算:重复操作浪费资源。
优化策略
- 算法优化:
- 选择合适的数据结构(如
HashMap
vsTreeMap
)。 - 降低时间复杂度。
- 选择合适的数据结构(如
- 缓存:
- 缓存热点数据(如 Guava Cache)。
- 内联和循环优化:
- 减少方法调用。
- 展开小循环,减少迭代开销。
- 字符串操作:
- 使用
StringBuilder
替代String
拼接。
- 使用
示例:字符串优化
public String buildString(List<String> items) {StringBuilder sb = new StringBuilder();for (String item : items) {sb.append(item);}return sb.toString();
}
三、Java 实践:实现高性能任务处理系统
以下通过 Spring Boot 实现一个任务处理系统,综合应用内存、并发、IO 和代码优化。
1. 环境准备
- 依赖(
pom.xml
):
<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>31.1-jre</version></dependency>
</dependencies>
2. 核心组件设计
- Task:任务实体。
- TaskProcessor:处理任务,优化并发和内存。
- TaskService:对外接口,优化 IO 和缓存。
Task 类
public class Task {private final String id;private final String data;private final long timestamp;public Task(String id, String data) {this.id = id;this.data = data;this.timestamp = System.currentTimeMillis();}public String getId() {return id;}public String getData() {return data;}public long getTimestamp() {return timestamp;}
}
TaskProcessor 类
public class TaskProcessor {private final ThreadPoolExecutor executor;private final ObjectPool<StringBuilder> sbPool;public TaskProcessor(int corePoolSize, int maxPoolSize) {this.executor = new ThreadPoolExecutor(corePoolSize,maxPoolSize,60L,TimeUnit.SECONDS,new LinkedBlockingQueue<>(1000),new ThreadPoolExecutor.CallerRunsPolicy());this.sbPool = new ObjectPool<>(StringBuilder::new, 100);}public CompletableFuture<String> process(Task task) {return CompletableFuture.supplyAsync(() -> {StringBuilder sb = sbPool.borrow();try {// 模拟处理sb.append(task.getData()).append("-processed-").append(task.getTimestamp());try {Thread.sleep(50); // 模拟耗时} catch (InterruptedException e) {Thread.currentThread().interrupt();}return sb.toString();} finally {sb.setLength(0);sbPool.release(sb);}}, executor);}public void shutdown() {executor.shutdown();}
}
TaskService 类
@Service
public class TaskService {private final TaskProcessor processor;private final Cache<String, String> cache;private final String logPath = "tasks.log";public TaskService() {this.processor = new TaskProcessor(4, 8);this.cache = CacheBuilder.newBuilder().maximumSize(1000).expireAfterWrite(10, TimeUnit.MINUTES).build();}public CompletableFuture<String> submitTask(String id, String data) {// 检查缓存String cached = cache.getIfPresent(id);if (cached != null) {return CompletableFuture.completedFuture(cached);}Task task = new Task(id, data);// 异步写入日志CompletableFuture.runAsync(() -> logTask(task));// 处理任务return processor.process(task).thenApply(result -> {cache.put(id, result);return result;});}private void logTask(Task task) {try (BufferedWriter writer = new BufferedWriter(new FileWriter(logPath, true))) {writer.write(task.getId() + ":" + task.getData() + "\n");} catch (IOException e) {System.err.println("Log failed: " + e.getMessage());}}@PreDestroypublic void shutdown() {processor.shutdown();}
}
3. 控制器
@RestController
@RequestMapping("/tasks")
public class TaskController {@Autowiredprivate TaskService taskService;@PostMapping("/submit")public CompletableFuture<String> submit(@RequestParam String id,@RequestParam String data) {return taskService.submitTask(id, data);}
}
4. 主应用类
@SpringBootApplication
public class PerformanceDemoApplication {public static void main(String[] args) {SpringApplication.run(PerformanceDemoApplication.class, args);}
}
5. 测试
测试 1:任务提交
- 请求:
POST http://localhost:8080/tasks/submit?id=1&data=Task1
POST http://localhost:8080/tasks/submit?id=2&data=Task2
- 响应:
"Task1-processed-1623456789"
- 分析:异步处理,对象池重用 StringBuilder。
测试 2:缓存命中
- 请求:
POST http://localhost:8080/tasks/submit?id=1&data=Task1
(重复)
- 响应:直接返回缓存结果。
- 分析:缓存避免重复处理。
测试 3:高并发
- 代码:
public class PerformanceTest {public static void main(String[] args) throws Exception {TaskService service = new TaskService();List<CompletableFuture<String>> futures = new ArrayList<>();// 提交 10000 个任务long start = System.currentTimeMillis();for (int i = 1; i <= 10000; i++) {futures.add(service.submitTask("id" + i, "data" + i));}CompletableFuture.allOf(futures.toArray(new CompletableFuture[0])).join();long end = System.currentTimeMillis();System.out.println("Total time: " + (end - start) + "ms");System.out.println("Processed: " + futures.size());} }
- 结果:
Total time: 5200ms Processed: 10000
- 分析:线程池高效调度,缓冲写入降低 IO 开销。
测试 4:GC 分析
- JVM 参数:
-Xms512m -Xmx512m -XX:+UseG1GC
- 工具:VisualVM 观察 GC。
- 结果:Minor GC 频率低,对象池减少分配。
- 分析:重用 StringBuilder 降低内存压力。
四、性能优化的进阶策略
1. JVM 调优
- 堆大小:
java -Xms2g -Xmx2g -jar app.jar
- GC 选择:
- G1:
-XX:+UseG1GC
- ZGC:
-XX:+UseZGC
(低停顿)。
- G1:
2. 分布式优化
- 负载均衡:
LoadBalancer balancer = new RoundRobinBalancer(nodes);
3. 监控与诊断
- 工具:
- JProfiler:分析 CPU 和内存。
- Prometheus + Grafana:监控指标。
- 日志:
logger.info("Task {} processed in {}ms", id, duration);
4. 注意事项
- 过度优化:避免复杂化简单逻辑。
- 测试驱动:基准测试(如 JMH)验证效果。
- 环境一致:生产和测试环境对齐。
五、总结
Java 性能优化涵盖内存管理、并发处理、IO 操作和代码执行。通过对象重用、线程池、异步 IO 和缓存等策略,可显著提升效率。本文结合 Spring Boot 实现了一个高性能任务系统,测试验证了优化效果。
相关文章:
Java 性能优化:从原理到实践的全面指南
性能优化是 Java 开发中不可或缺的一环,尤其在高并发、大数据和分布式系统场景下,优化直接影响系统响应速度、资源利用率和用户体验。Java 作为一门成熟的语言,提供了丰富的工具和机制支持性能调优,但优化需要深入理解 JVM、并发模…...
基于ssm网络游戏推荐系统(源码+lw+部署文档+讲解),源码可白嫖!
摘要 当今社会进入了科技进步、经济社会快速发展的新时代。国际信息和学术交流也不断加强,计算机技术对经济社会发展和人民生活改善的影响也日益突出,人类的生存和思考方式也产生了变化。传统网络游戏管理采取了人工的管理方法,但这种管理方…...
HTTP:五.WEB服务器
web服务器 定义:实现提供资源或应答的提供者都可以谓之为服务器!web服务器工作内容 接受建立连接请求 接受请求 处理请求 访问报文中指定的资源 构建响应 发送响应 记录事务处理过程 Web应用开发用到的一般技术元素 静态元素:html, img,js,Css,SWF,MP4 动态元素:PHP,…...
synchronized轻量级锁的自旋之谜:Java为何在临界区“空转“等待?
从餐厅等位理解自旋锁的智慧 想象两家不同的餐厅: 传统餐厅:没座位时顾客去逛街(线程挂起,上下文切换)网红餐厅:没座位时顾客在门口短时间徘徊(线程自旋,避免切换) Ja…...
基于redis 实现我的收藏功能优化详细设计方案
基于redis 实现我的收藏功能优化详细设计方案 一、架构设计 +---------------------+ +---------------------+ | 客户端请求 | | 数据存储层 | | (收藏列表查询) | | (Redis Cluster) | +-------------------…...
【深度学习与大模型基础】第10章-期望、方差和协方差
一、期望 ——————————————————————————————————————————— 1. 期望是什么? 期望(Expectation)可以理解为“长期的平均值”。比如: 掷骰子:一个6面骰子的点数是1~6&#x…...
JavaScript 性能优化实战:深入探讨 JavaScript 性能瓶颈,分享优化技巧与最佳实践
在当今 Web 应用日益复杂的时代,JavaScript 性能对于用户体验起着决定性作用。缓慢的脚本执行会导致页面加载延迟、交互卡顿,严重影响用户留存率。本文将深入剖析 JavaScript 性能瓶颈,并分享一系列实用的优化技巧与最佳实践,助你…...
上篇:《排序算法的奇妙世界:如何让数据井然有序?》
个人主页:strive-debug 排序算法精讲:从理论到实践 一、排序概念及应用 1.1 基本概念 **排序**:将一组记录按照特定关键字(如数值大小)进行递增或递减排列的操作。 1.2 常见排序算法分类 - **简单低效型**ÿ…...
目前状况下,计算机和人工智能是什么关系?
目录 一、计算机和人工智能的关系 (一)从学科发展角度看 计算机是基础 人工智能是计算机的延伸和拓展 (二)从技术应用角度看 二、计算机系学生对人工智能的了解程度 (一)基础层面的了解 必备知识 …...
【复旦微FM33 MCU 底层开发指南】高级定时器ATIM
0 前言 本系列基于复旦微FM33LC0系列MCU的DataSheet编写,提供基于寄存器开发指南、应用技巧、注意事项等 本文章及本系列其他文章将持续更新,本系列其它文章请跳转↓↓↓ 【复旦微FM33 MCU 寄存器开发指南】总集篇 本文章最后更新日期:2025…...
vdso概念及原理,vdso_fault缺页异常,vdso符号的获取
一、背景 vdso的全称是Virtual Dynamic Shared Object,它是一个特殊的共享库,是在编译内核时生成,并在内核镜像里某一段地址段作为该共享库的内容。vdso的前身是vsyscall,为了兼容一些旧的程序,x86上还是默认加载了vs…...
4.13学习总结
学习完异常和文件的基本知识 完成45. 跳跃游戏 II - 力扣(LeetCode)的算法题,对于我来说,用贪心的思路去写该题是很难理解的,很难想到,理解了许久,也卡了很久。...
Day14:关于MySQL的索引——创、查、删
前言:先创建一个练习的数据库和数据 1.创建数据库并创建数据表的基本结构 -- 创建练习数据库 CREATE DATABASE index_practice; USE index_practice;-- 创建基础表(包含CREATE TABLE时创建索引) CREATE TABLE products (id INT PRIMARY KEY…...
概率论与数理统计核心知识点与公式总结(就业版)
文章目录 概率论与数理统计核心知识点与公式总结(附实际应用)一、概率论基础1.1 基本概念1.2 条件概率与独立性 二、随机变量及其分布2.0 随机变量2.0 分布函数(CDF)2.1 离散型随机变量2.2 连续型随机变量2.3 多维随机变量2.3.1 联…...
AF3 ProteinDataset类的_patch方法解读
AlphaFold3 protein_dataset模块 ProteinDataset 类 _patch 方法的主要目的是围绕锚点残基(anchor residues)裁剪蛋白质数据,提取一个局部补丁(patch)作为模型输入。 源代码: def _patch(self, data):"""Cut the data around the anchor residues."…...
openssh 10.0在debian、ubuntu编译安装 —— 筑梦之路
OpenSSH 10.0 发布:一场安全与未来兼顾的大升级 - Linux迷 OpenSSH: Release Notes sudo apt-get updatesudo apt install build-essential zlib1g-dev libssl-dev libpam0g-dev libselinux1-devwget https://cdn.openbsd.org/pub/OpenBSD/OpenSSH/portable/opens…...
Go 跨域中间件实现指南:优雅解决 CORS 问题
在开发基于 Web 的 API 时,尤其是前后端分离项目,**跨域问题(CORS)**是前端开发人员经常遇到的“拦路虎”。本文将带你了解什么是跨域、如何在 Go 中优雅地实现一个跨域中间件,支持你自己的 HTTP 服务或框架如 net/htt…...
【数据结构_6】双向链表的实现
一、实现MyDLinkedList(双向链表) package LinkedList;public class MyDLinkedList {//首先我们要创建节点(因为双向链表和单向链表的节点不一样!!)static class Node{public String val;public Node prev…...
【双指针】专题:LeetCode 1089题解——复写零
复写零 一、题目链接二、题目三、算法原理1、先找到最后一个要复写的数——双指针算法1.5、处理一下边界情况2、“从后向前”完成复写操作 四、编写代码五、时间复杂度和空间复杂度 一、题目链接 复写零 二、题目 三、算法原理 解法:双指针算法 先根据“异地”操…...
Foxmail邮件客户端跨站脚本攻击漏洞(CNVD-2025-06036)技术分析
Foxmail邮件客户端跨站脚本攻击漏洞(CNVD-2025-06036)技术分析 漏洞背景 漏洞编号:CNVD-2025-06036 CVE编号:待分配 厂商:腾讯Foxmail 影响版本:Foxmail < 7.2.25 漏洞类型&#x…...
39.[前端开发-JavaScript高级]Day04-函数增强-argument-额外知识-对象增强
JavaScript函数的增强知识 1 函数属性和arguments 函数对象的属性 认识arguments arguments转Array 箭头函数不绑定arguments 函数的剩余(rest)参数 2 纯函数的理解和应用 理解JavaScript纯函数 副作用概念的理解 纯函数的案例 判断下面函数是否是纯…...
0x05.为什么 Redis 设计为单线程?6.0 版本为何引入多线程?
回答重点 单线程设计原因: Redis 的操作是基于内存的,其大多数操作的性能瓶颈主要不是 CPU 导致的使用单线程模型,代码简便的同时也减少了线程上下文切换带来的性能开销Redis 在单线程的情况下,使用 I/O 多路复用模型就可以提高 Redis 的 I/O 利用率了6.0 版本引入多线程的…...
CST1019.基于Spring Boot+Vue智能洗车管理系统
计算机/JAVA毕业设计 【CST1019.基于Spring BootVue智能洗车管理系统】 【项目介绍】 智能洗车管理系统,基于 Spring Boot Vue 实现,功能丰富、界面精美 【业务模块】 系统共有三类用户,分别是:管理员用户、普通用户、工人用户&…...
CST1018.基于Spring Boot+Vue滑雪场管理系统
计算机/JAVA毕业设计 【CST1018.基于Spring BootVue滑雪场管理系统】 【项目介绍】 滑雪场管理系统,基于 Spring Boot Vue 实现,功能丰富、界面精美 【业务模块】 系统共有两类用户,分别是管理员和普通用户,管理员负责维护后台数…...
剖析 Rust 与 C++:性能、安全及实践对比
1 性能对比:底层控制与运行时开销 1.1 C 的性能优势 C 给予开发者极高的底层控制能力,允许直接操作内存、使用指针进行精细的资源管理。这使得 C 在对性能要求极高的场景下,如游戏引擎开发、实时系统等,能够发挥出极致的性能。以…...
SDHC接口协议底层传输数据是安全的
SDHC(Secure Digital High Capacity)接口协议在底层数据传输过程中确实包含校验机制,以确保数据的完整性和可靠性。以下是关键点的详细说明: 物理层与数据链路层的校验机制 物理层(Electrical Layer)&…...
Gateway-网关-分布式服务部署
前言 什么是API⽹关 API⽹关(简称⽹关)也是⼀个服务, 通常是后端服务的唯⼀⼊⼝. 它的定义类似设计模式中的Facade模式(⻔⾯模式, 也称外观模式). 它就类似整个微服务架构的⻔⾯, 所有的外部客⼾端访问, 都需要经过它来进⾏调度和过滤. 常⻅⽹关实现 Spring Cloud Gateway&a…...
c++STL——string学习的模拟实现
文章目录 string的介绍学习的意义auto关键字和范围forstring中的常用接口构造和析构对string得容量进行操作string的访问迭代器(Iterators):运算符[ ]重载 string类的修改操作非成员函数 string的模拟实现不同平台下的实现注意事项模拟实现部分所有的模拟实现函数预…...
【寻找Linux的奥秘】第四章:基础开发工具(下)
请君浏览 前言1. 自动化构建1.1 背景1.2 基本语法1.3 make的运行原理1.4通用的makefile 2. 牛刀小试--Linux第一个小程序2.1 回车与换行2.2 行缓冲区2.3 倒计时小程序2.4 进度条小程序原理代码 3. 版本控制器git3.1 认识3.2 git的使用三板斧 3.3 其他 4. 调试器gdb/cgdb4.1 了解…...
RK3588上Linux系统编译C/C++ Demo时出现BUG:The C/CXX compiler identification is unknown
BUG的解决思路 BUG描述:解决方法:首先最重要的一步:第二步:正确设置gcc和g的路径方法一:使用本地系统中安装的 aarch64-linux-gnu-gcc 和 aarch64-linux-gnu-g方法二:下载使用官方指定的交叉编译工具方法三…...
记录一次/usr/bin/ld: 找不到 -lOpenSSL::SSL
1、cmake 报错内容如下: /usr/bin/ld: 找不到 -lOpenSSL::SSL /usr/bin/ld: 找不到 -lOpenSSL::Crypto2、一开始以为库没有正确安装 sudo yum install openssl-devel然后查看openssl 结果还是报错! 3、尝试卸载安装都不管用,网上搜了好多…...
[16届蓝桥杯 2025 c++省 B] 水质检测
思路:分类讨论,从左到右枚举,判断当前的河床和下一个河床的距离是第一行更近还是第二行更近还是都一样近,分成三类编写代码即可 #include<iostream> using namespace std; int main(){string s1,s2;cin>>s1>>…...
基于PySide6与pycatia的CATIA绘图比例智能调节工具开发全解析
引言:工程图纸自动化处理的技术革新 在机械设计领域,CATIA图纸的比例调整是高频且重复性极强的操作。传统手动调整方式效率低下且易出错。本文基于PySide6pycatia技术栈,提出一种支持智能比例匹配、实时视图控制、异常自处理的图纸批处理方案…...
四、Appium Inspector
一、介绍 Appium Inspector 是一个用于移动应用自动化测试的图形化工具,主要用于检查和交互应用的 UI 元素,帮助生成和调试自动化测试脚本。类似于浏览器的F12(开发者工具),Appium Inspector 的主要作用包括: 1.检查 UI 元素 …...
玩转Docker | 使用Docker部署MicroBin粘贴板
玩转Docker | 使用Docker部署MicroBin粘贴板 前言一、MicroBin介绍MicroBin 简介主要特点二、系统要求环境要求环境检查Docker版本检查检查操作系统版本三、部署MicroBin服务下载镜像创建容器检查容器状态检查服务端口安全设置四、访问MicroBin服务访问MicroBin首页登录管理后台…...
BGP分解实验·23——BGP选路原则之路由器标识
在选路原则需要用到Router-ID做选路决策时,其对等体Router-ID较小的路由将被优选;其中,当路由被反射时,包含起源器ID属性时,该属性将代替router-id做比较。 实验拓扑如下: 实验通过调整路由器R1和R2的rout…...
MQTT:单片机中MQTTClient-C移植定时器功能
接下来我们完善MQTTTimer.c和MQTTTimer.h两个功能 MQTTTimer.h void TimerInit(Timer* timer); 功能:此函数用于对 Timer 结构体进行初始化。在 MQTT 客户端里,定时器被用于追踪各种操作的时间,像连接超时、心跳包发送间隔等。初始化操作会…...
可拖动的关系图谱原型案例
关系图谱是一种以图结构形式组织和呈现实体间复杂关联关系的可视化数据模型。它通过节点和线构建多维度网络,能直观揭示隐藏的群体特征和传播路径。在社交网络分析、智能推荐系统、知识图谱构建等领域广泛应用。 软件版本:Axure RP 9 作品类型…...
CST1016.基于Spring Boot+Vue高校竞赛管理系统
计算机/JAVA毕业设计 【CST1016.基于Spring BootVue高校竞赛管理系统】 【项目介绍】 高校竞赛管理系统,基于 DeepSeek Spring AI Spring Boot Vue 实现,功能丰富、界面精美 【业务模块】 系统共有两类用户,分别是学生用户和管理员用户&a…...
从三次方程到复平面:复数概念的奇妙演进(二)
注:本文为 “复数 | 历史 / 演进” 相关文章合辑。 因 csdn 篇幅限制分篇连载,此为第二篇。 生料,不同的文章不同的点。 机翻,未校。 History of Complex Numbers 复数的历史 The problem of complex numbers dates back to …...
PCL 点云投影至指定平面
文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 之前的文章中介绍过一个点在平面上的投影坐标,其主要的思路就是利用投影垂线与平面法向量平行的特性,通过推导出的投影公式可以很容易的计算出在某点在某一平面内的投影点。因此只需要重复该过程就可以将整个点云…...
批量将文件名称、文件路径、文件扩展名提取到 Excel 清单
在数字化时代,文件的高效管理至关重要。当我们想要对磁盘中的文件进行整理,想要获取多个文件夹中的文件和路径信息,就需要现将这些文件的名称及路径信息提取出来。本文将介绍一种实用的批量提取技术,帮助用户优化文件管理流程&…...
KWDB创作者计划—KWDB场景创新:多模态数据融合与边缘智能的产业实践
引言:AIoT时代的数据基座重构 在工业物联网设备数量突破千亿、边缘计算节点覆盖率达75%的2025年,传统数据库面临多模态数据处理效率低下、边缘端算力利用率不足、跨域数据协同困难等核心挑战。KWDB(KaiwuDB Community Edition)通过…...
计算机系统概论
1. 计算机系统的基本组成 计算机系统由 硬件系统 和 软件系统 两大部分协同工作: 硬件系统: 基于冯诺依曼体系结构(存储程序原理),包含五大核心部件: 运算器(ALU):执行算…...
Android Cmake构建的项目,需不需要配置指定ndk及版本
在 CMake 构建的 Android 项目中,是否需要显式配置 NDK 及其版本,取决于项目的具体需求和环境。以下是详细分析和建议: 1. 是否需要显式配置 NDK 及版本? 情况 1:Android Studio 自动管理 NDK(推荐&#x…...
国内AI大模型卷到什么程度了?
目录 1.开源大模型更有前景吗? 2.参数越大真的越牛逼吗? 3.榜单排名有意义吗? 大家好这里是AIWritePaper官方账号,官网👉AIWritePaper~ 大模型开源更有前景? 参数越大真的越牛逼吗? 榜单排…...
【HDFS入门】Hadoop 2.0+ HDFS核心架构深度解析:高可用设计揭秘
目录 1 HDFS核心架构概述 2 高可用设计背景 3HDFS核心组件 3.1 Active与Standby NameNode 3.2 JournalNode 3.3 ZKFailoverController(ZKFC) 3.4 DataNode 4 高可用设计的工作流程 写入阶段: 元数据同步: 健康监测&…...
RabbitMQ安装
RabbitMQ安装 Ubuntu环境安装 一、安装Erlang #更新软件包 sudo apt-get update #安装erlang sudo apt-get install erlang 二、安装RabbitMQ #更新软件包 sudo apt-get update #安装rabbitmq sudo apt-get install rabbitmq-server #确认安装结果 systemctl status rabbitmq-…...
2022 CCPC Henan Provincial Collegiate Programming Contest K 复合函数
补题链接 看网上题解很少,来写一份,这题个人觉得思维难度不是特别大,难度主要在于代码准确度,首先将问题转化成 x x x 向 f ( x ) f(x) f(x) 连边,这一步转化应该是比较容易想到的,通过手模样例,会有类…...
Linux : 多线程互斥
目录 一 前言 二 线程互斥 三 Mutex互斥量 1. 定义一个锁(造锁) 2. 初始化锁 3. 上锁 4. 解锁 5. 摧毁锁 四 锁的使用 五 锁的宏初始化 六 锁的原理 1.如何看待锁? 2. 如何理解加锁和解锁的本质 七 c封装互斥锁 八 可重入…...