04 2024 档案

摘要:1.AtomicInteger、AtomicLong、AtomicBoolean、AtomicReference:基础 // atomicInteger:整型原子类 AtomicInteger atomicInteger = new AtomicInteger(0); atomicInteger.i 阅读全文
posted @ 2024-04-29 02:02 Yfeil 阅读(183) 评论(0) 推荐(0) 编辑
摘要:1.runAsync、supplyAsync、get、join:开启异步任务,获取结果。 // runAsync:没有返回值 CompletableFuture<Void> future = CompletableFuture.runAsync(() -> { System.out.println( 阅读全文
posted @ 2024-04-28 20:07 Yfeil 阅读(110) 评论(0) 推荐(0) 编辑
摘要:老古董(低效,不建议用): 原理是所有操作都加同步块 // Vector Vector<String> vector = new Vector<String>(); // Hashtable Hashtable<Integer, String> hashtable = new Hashtable<I 阅读全文
posted @ 2024-04-23 02:17 Yfeil 阅读(1356) 评论(0) 推荐(0) 编辑
摘要:冒泡排序: 时间复杂度:O(n^2) 通过不断交换相邻的元素,将大的元素“浮”到数组的后面。 public static void bubbleSort(int[] arr) { // 外层循环控制排序轮数,每轮将最大的元素 "浮" 到末尾 for (int i = 0; i < arr.lengt 阅读全文
posted @ 2024-04-22 05:33 Yfeil 阅读(17) 评论(0) 推荐(0) 编辑
摘要:先假设有 x、y、z 三个代数 再假设一个已知条件 x > y 根据已知条件推断,y 不可能是最大值,最大值只会在 x 和 z 之间产生 因此 min(x, z) 即可排除最大值 但是 z 有可能小于 y,因此还需要排除最小值 最终使用 max(y, min(x, z)) 即可得出中间值 如何把三个 阅读全文
posted @ 2024-04-20 09:31 Yfeil 阅读(141) 评论(0) 推荐(0) 编辑
摘要:冒泡排序: 时间复杂度:O(n^2) 冒泡排序就像水里的气泡一样,轻的气泡会一点一点地浮到水面。在这个算法中,我们将待排序的元素比喻成气泡,通过比较相邻元素的值,让较大的元素慢慢“浮”到数组的末端。 具体步骤如下: 比较相邻的两个元素,如果前一个比后一个大(假设我们要从小到大排序),就交换它们的位置 阅读全文
posted @ 2024-04-20 01:00 Yfeil 阅读(39) 评论(0) 推荐(0) 编辑
摘要:读程序{ 读缓存(){ //命中 return 数据; }else{ //未命中 lock 读缓存(){//双检 return 数据; }else{ 读数据库 改缓存 } unlock } } 写程序{ lock 删缓存 改数据库 unlock } 阅读全文
posted @ 2024-04-17 20:03 Yfeil 阅读(26) 评论(0) 推荐(0) 编辑
摘要:由于没在官网查到相关资料,以下结论来自互联网第三方博客搜集整理后,准确性无法保证,仅供参考。 屏障作用: 可见性:当一条线程修改了一个变量的值,新值会立即被写入主内存,同时其他线程读取该变量时会从主内存中读取最新值,而不是使用线程缓存中的值。 有序性:编译器和处理器可能会对指令进行重排以提高性能,但 阅读全文
posted @ 2024-04-10 01:13 Yfeil 阅读(475) 评论(0) 推荐(0) 编辑
摘要:下载地址:v2.1.8-1预览版 · Yfeil/VisualVM汉化 - Gitee.com 阅读全文
posted @ 2024-04-02 19:21 Yfeil 阅读(960) 评论(1) 推荐(1) 编辑