多线程
文章平均质量分 52
java_gp
出身蝼蚁
当有鸿鹄之志
命如纸薄
却有不屈之心
乾坤未定
你我皆是黑马
展开
-
JUC——ThreadLocal是怎么解决并发安全的?
ThreadLocal是Java提供的一种保存线程私有信息的机制,因为其在整个线程生命周期内有效,所以可以方便的在一个线程关联的不同业务模块之间传递信息,比如事务ID、Cookie等上下文相关信息。ThreadLocal为每一个线程维护变量的副本,把共享数据的可见范围限制在同一个线程之内,实现原理是:在ThreadLocal类中有一个Map,用于存储每一个线程的变量的副本。原创 2024-05-14 09:33:07 · 227 阅读 · 0 评论 -
Java原子操作CAS(一)
一、什么是原子操作?如何实现原子操作?假定有两个操作 A 和 B,如果从执行 A 的线程来看,当另一个线程执行 B 时,要么将 B 全部执行完,要么完全不执行 B,那么 A 和 B 对彼此来说是原子的。1、CAS可以认为是乐观锁:*顾名思义就是保持一种乐观的态度,我们认为系统中的事务并发更新不会很频繁,即使冲突了也没事,大不了重新来一次。*它的基本思想就是每次提交一个事务更新时,我们想看...原创 2020-04-20 10:18:31 · 225 阅读 · 0 评论 -
多线程(四)ThreadLocal与Synchonized的比较
ThreadLocal和synchronized都用于解决多线程并发访问。ThreadLocal与Synchronized本质区别:①ThreadLocal为每个线程都提供了变量的副本,使得每个线程在某一时间访问到的并非同一个对象,这样就隔离了多个线程对数据的共享。②synchronized是利用锁的机制,使变量或代码块在某一时刻仅仅能被一个线程访问。例:Spring的事务就借助了ThreadLocal类。 Spring会从数据库连接池中获得一个connection,然后会把connec原创 2020-07-30 13:58:15 · 193 阅读 · 0 评论 -
多线程:线程之间的共享和协作(二)
线程间的共享:synchronized内置锁线程开始运行,拥有自己的栈空间,就如同一个脚本一样,按照既定的代码一步一步的执行,直到终止。但是,每个运行中的线程,如果仅仅是孤立的运行,那么没有一点价值,或者说价值很少,如果多个线程能够相互配合完成工作,包括数据之间的共享,写统处理事情。这将会带来巨大的价值。Java支持多个线程同时访问一个对象或者对象的成员变量,关键字synchroniz...原创 2020-04-16 11:16:38 · 360 阅读 · 0 评论 -
多线程:线程之间的共享和协作(一)
1.线程之间的共享和协作1.1什么是进程:进程是操作系统进行资源分配的最小单位,其中资源包括:CPU、内存空间、 磁盘 IO 等,同一进程中的多条线程共享该进程中的全部系统资源,而进程和进程 之间是相互独立的。1.2什么是线程:线程是 CPU 调度的最小单位,必须依赖于进程而存在。 2.并行和并发的概念: 并行:同时执行不同的任务;并发:不能脱离时间单位,交替...原创 2020-04-14 12:47:44 · 485 阅读 · 1 评论 -
多线程:(三)并发编程常见面试题!
一、在Java中守护线程和用户线程的区别? Java中的线程分为两种: 守护线程(Daemon)和用户线程(User)。 任何线程都可以设置为守护线程和用户线程,通过方法Thread.setDaemon(boolon);设置为 true 则把该线程设置为守护线程,反之则为用户线程。Thread.setDaemon(boolon);必须在Thread.start()之前调用,否则运行时会抛出异常。 两者的区别:唯一的区别是判断虚拟机(JV...原创 2020-07-08 14:53:38 · 443 阅读 · 0 评论