随笔分类 -  java

摘要:各种锁的理解 公平锁、非公平锁 公平锁:先到先得(不可插队) 非公平锁:达者为先(可插队) >默认 public ReentrantLock() { //默认非公平锁 sync = new NonfairSync(); } //重载的构造方法,通过fair控制是否公平 public Reentran 阅读全文
posted @ 2023-11-16 17:09 高同学,你好 阅读(148) 评论(0) 推荐(0) 编辑
摘要:原子引用 带版本号的原子操作! 解决ABA问题,引入原子引用(乐观锁思想) AtomicStampedReference类解决ABA问题 package org.example.cas; import java.util.concurrent.TimeUnit; import java.util.c 阅读全文
posted @ 2023-11-14 19:18 高同学,你好 阅读(75) 评论(0) 推荐(0) 编辑
摘要:深入理解CAS 什么是CAS 为什么要学CAS:大厂你必须深入研究底层!有所突破! java层面的cas >compareAndSet compareAndSet(int expectedValue, int newValue) 期望并更新,达到期望值就更新、否则就不更新! package org. 阅读全文
posted @ 2023-11-10 09:11 高同学,你好 阅读(70) 评论(0) 推荐(0) 编辑
摘要:彻底玩转单例模式 单例中最重要的思想 >构造器私有! 恶汉式、懒汉式(DCL懒汉式!) 恶汉式 package single; //饿汉式单例(问题:因为一上来就把对象加载了,所以可能会导致浪费内存) public class Hungry { /* * 如果其中有大量的需要开辟的空间,如new b 阅读全文
posted @ 2023-11-09 13:54 高同学,你好 阅读(67) 评论(0) 推荐(0) 编辑
摘要:Volatile 保证可见性 private volatile static Integer num = 0; 使用了volatile关键字,即可保证它本身可被其他线程的工作内存感知,即变化时也会被同步变化。 不保证原子性 原子性:不可分割 线程A在执行任务时是不可被打扰的,也不能被分割,要么同时成 阅读全文
posted @ 2023-11-08 14:19 高同学,你好 阅读(59) 评论(1) 推荐(0) 编辑
摘要:JMM 请你谈谈对Volatile的理解 Volatile是java虚拟机提供的轻量级的同步机制 1、保证可见性 2、不保证原子性 3、禁止指令重排 什么是JMM JVM->java虚拟机 JMM->java内存模型,不存在的东西,概念!约定 关于JMM的一些同步的约定: 线程解锁前,必须把共享变量 阅读全文
posted @ 2023-11-07 08:21 高同学,你好 阅读(91) 评论(0) 推荐(0) 编辑
摘要:异步回调 Future设计的初衷:对将来的某个事件的结果进行建模 在Future类的子类中可以找到CompletableFuture,在介绍中可以看到这是为非异步的请求使用一些异步的方法来处理 点进具体实现类中,查看方法,可以看到CompletableFuture中的异步内部类,里面是实现的异步方法 阅读全文
posted @ 2023-11-06 18:59 高同学,你好 阅读(95) 评论(0) 推荐(0) 编辑
摘要:ForkJoin 什么是ForkJoin ForkJoin在JDK1.7,并发执行任务!大数据量时提高效率。 大数据:Map Reduce(把大任务拆分成小任务) ForkJoin特点:工作窃取 为什么可以取窃取其他线程的任务呢?因为这里面维护的都是双端队列(即队列的两端都可以取元素) ForkJo 阅读全文
posted @ 2023-11-06 12:59 高同学,你好 阅读(145) 评论(0) 推荐(0) 编辑
摘要:Stream流式计算 什么是Stream流式计算 大数据:存储+计算 集合、MySql这些的本质都是存储东西的; 计算都应该交给流来操作! 一个案例说明:函数式接口、lambda表达式、链式编程、Stream流式计算 package org.example.stream; import java.u 阅读全文
posted @ 2023-11-05 20:19 高同学,你好 阅读(104) 评论(0) 推荐(0) 编辑
摘要:四大函数式接口(必备) 程序员:泛型、反射、注解、枚举 新时代程序员:lambda表达式、链式编程、函数式接口、Stream流式计算 函数式接口:只有一个方法的接口 @FunctionalInterface public interface Runnable { public abstract vo 阅读全文
posted @ 2023-11-05 12:20 高同学,你好 阅读(474) 评论(0) 推荐(0) 编辑
摘要:线程池(重点) 线程池:三大方法、七大参数、四种拒绝策略 池化技术 程序的运行,本质:占用系统的资源!优化资源的使用!-> 池化技术(线程池、连接池、对象池......);创建和销毁十分消耗资源 池化技术:事先准备好一些资源,有人要用就拿,拿完用完还给我。 线程池的好处: 1、降低资源消耗 2、提高 阅读全文
posted @ 2023-11-04 22:45 高同学,你好 阅读(80) 评论(0) 推荐(0) 编辑
摘要:阻塞队列 阻塞 队列 队列的特性:FIFO(fist inpupt fist output)先进先出 不得不阻塞的情况 什么情况下会使用阻塞队列:多线程并发处理、线程池 学会使用队列 添加、移除 四组API 方式 抛出异常 不抛出异常,有返回值 阻塞等待 超时等待 添加 add offer put 阅读全文
posted @ 2023-11-04 18:53 高同学,你好 阅读(97) 评论(0) 推荐(0) 编辑
摘要:读写锁 ReadWriteLock ReadWriteLock只存在一个实现类那就是ReentrantReadWriteLock,他可以对锁实现更加细粒化的控制 读的时候可以有多个阅读器线程同时参与,写的时候只希望写入线程是独占的 Demo: package org.example.rw; impo 阅读全文
posted @ 2023-11-04 15:40 高同学,你好 阅读(61) 评论(0) 推荐(0) 编辑
摘要:常用的辅助类 CountDownLatch 这是一个JUC计数器辅助类,计数器有加有减,这是减。 使用方法 package org.example.demo; import java.util.concurrent.CountDownLatch; //线程计数器 public class Count 阅读全文
posted @ 2023-11-04 08:24 高同学,你好 阅读(97) 评论(0) 推荐(0) 编辑
摘要:Callable(简单) callable接口和runnable接口类似,都是为了执行另外一条线程而设计的,区别是Runnable不会返回结果也不会抛出异常。 1、可以有返回值 2、可以抛出异常 3、方法不同;run()/call(); Runnable 实现Runnable接口,重写run方法,无 阅读全文
posted @ 2023-11-03 19:25 高同学,你好 阅读(83) 评论(0) 推荐(0) 编辑
摘要:集合类不安全 List不安全 单线程情况下集合类和很多其他的类都是安全的,因为同一时间只有一个线程在对他们进行修改,但是如果是多线程情况下,那么集合类就不一定是安全的,可能会出现一条线程正在修改的同时另一条线程启动来对这个集合进行修改,这种情况下就会导致发生并发修改异常(在jdk11的环境下多次测试 阅读全文
posted @ 2023-11-03 09:34 高同学,你好 阅读(323) 评论(0) 推荐(0) 编辑
摘要:8锁现象 八锁->就是关于锁的八个问题 锁是什么,如何判断锁的是谁 对象、class模板 深刻理解锁 锁的东西无外乎就两样:1、同步方法的调用者,2、Class模板。 同一个锁中,只有当前线程资源释放后才会被下一个线程所接手。 同步方法的调用者是两个不同的实例时,互不相关。 静态同步方法(stati 阅读全文
posted @ 2023-11-02 21:43 高同学,你好 阅读(328) 评论(0) 推荐(0) 编辑
摘要:生产者和消费者问题 synchronized版-> wait/notify juc版->Lock 面试:单例模式、排序算法、生产者和消费者、死锁 生产者和消费者问题 Synchronized版 package org.example.pc; public class A { public stati 阅读全文
posted @ 2023-11-02 20:02 高同学,你好 阅读(101) 评论(0) 推荐(0) 编辑
摘要:Lock锁(重点) 传统的synchronized 传统的解决多线程并发导致的一些问题我们会使用synchronized关键字来解决,synchronized的本质就是队列、锁。 Lock的实现类有:可重复锁(最常用)、读锁、写锁 在创建可重复锁时,可传入boolean类型值来决定该锁是公平锁(先来 阅读全文
posted @ 2023-11-02 18:47 高同学,你好 阅读(189) 评论(0) 推荐(1) 编辑
摘要:进程和线程 进程 一个程序,如QQ.exe,是程序的集合 一个进程往往可以包含多个线程,至少包含一个 java默认有两个线程,GC垃圾回收线程和Main线程 线程:一个进程中的各个功能 java无法真正的开启线程,因为java是运行在虚拟机上的,所以只能通过C++,通过native本地方法调用C++ 阅读全文
posted @ 2023-11-02 17:47 高同学,你好 阅读(145) 评论(0) 推荐(1) 编辑

点击右上角即可分享
微信分享提示