Java线程<第五篇>:线程池 utils包提供开了 ExecutorService 线程池的实现,主要目的是为了重复利用线程,提高系统效率。 Thread是一个重量级的资源,创建、启动以及销毁都是比较耗费系统资源的,因此使用线程池来管理线程是一个非常重要的编程习惯。 1、Thread new Thread(new Runnable() { @Override public void 后端 2025年06月17日 70 点赞 0 评论 9896 浏览
JVM 执行引擎的作用及工作过程 下面就要讲代码到底是怎么执行的。在讲源码之前,我们看看从流程角度到底是怎么运行的。 image.png image.png 执行引擎的概述 执行引擎是 Java 虚拟机核心的组成部分之一。 “虚拟机”是一个相对于“物理机”的概念,这两种机器都有代码执行能力,其区别是物理机的执行引擎是直接建立在处理器、缓存、指令集和操作系统层面上的,而虚拟机的执行引擎则是由软件自行实现的, 后端 2025年06月17日 144 点赞 0 评论 17717 浏览
Spring Cloud Gateway API接口安全设计(加密 、签名) 本文属于转载,原文链接为: 1 防止数据抓包窃取 1.1 风险简述 简述:当用户登录时,恶意攻击者可以用抓包工具可以拿到用户提交的表单信息,可以获取用户的账号密码,进而可以恶意访问网站。 image.png 1.2 RSA 非对称加密 1.2.1 RSA简介 RSA加密算法是一种非对称加 后端 2025年06月17日 197 点赞 0 评论 11195 浏览
JVM调优参数 JVM调优参数可以分为以下几类: 1.堆内存调优参数: -Xms:初始堆大小 -Xmx:最大堆大小 -Xmn:新生代大小 -XX:NewRatio:新生代和老年代的比例 -XX:SurvivorRatio:Eden区和Survivor区的比例 2.GC调优参数: -XX:+UseSerialGC:使用串行垃圾回收器 -XX:+UseParallelGC:使用并行垃圾回收器 -XX:+UseConc 后端 2025年06月17日 93 点赞 0 评论 11626 浏览
leetcode-数组中重复的数据 给你一个长度为 n 的整数数组 nums ,其中 nums 的所有整数都在范围 [1, n] 内,且每个整数出现 一次 或 两次 。请你找出所有出现 两次 的整数,并以数组形式返回。 你必须设计并实现一个时间复杂度为 O(n) 且仅使用常量额外空间的算法解决此问题。 示例 1: 输入:nums = [4,3,2,7,8,2,3,1] 输出:[2,3] 示例 2: 输入:nums = [1,1,2] 后端 2025年06月17日 61 点赞 0 评论 16410 浏览
Spring Cloud Gateway负载均衡 一、Spring Cloud Gateway 我们都知道Spring Cloud Gateway是一个基于Spring Boot、Spring WebFlux、Project Reactor构建的高性能网关,旨在提供简单、高效的API路由。Spring Cloud Gateway基于Netty运行,因此在传统Servlet容器中或者打成war包是不能正常运行的。 二、Spring Cloud Ga 后端 2025年06月17日 171 点赞 0 评论 2050 浏览
使用redis实现分布式锁 几种redis分布式锁实现 一、简单的分布式锁实现 利用下面的命令,实现一个带自动删除的分布式锁 set key value px 毫秒 nx 编写两个lua脚本文件 加锁操作--lock.lua -- 利用set key value px milliseconds nx 命令实现分布式锁 redis.call('set',KEYS[1],ARGV[1],'px',ARGV[2],'nx') 后端 2025年06月17日 54 点赞 0 评论 7061 浏览
leetcode-矩阵置零 给定一个 m x n 的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 示例 1: 输入:matrix = [[1,1,1],[1,0,1],[1,1,1]] 输出:[[1,0,1],[0,0,0],[1,0,1]] 示例 2: 输入:matrix = [[0,1,2,0],[3,4,5,2],[1,3,1,5]] 输出:[[0,0,0,0],[ 后端 2025年06月17日 56 点赞 0 评论 13299 浏览
leetcode数据结构题集 - 草稿 题目1: 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。 你可以按任意顺序返回答案。 示例 1: 输入:nums = [2,7,11,15], target = 9 输出:[0,1] 解释:因 后端 2025年06月15日 32 点赞 0 评论 3489 浏览
iOS常见算法题 1、二分查找 已知一个有序数组, 和一个 key, 要求从数组中找到 key 对应的索引位置 int binaryFind(int *arr,int len,int key){ int min=0,max=len-1,mid; while (min <= max) { mid = (min+max)/2; if (key < arr[mi 后端 2025年06月15日 61 点赞 0 评论 17306 浏览