欢迎来到<并发王者课>,本文是该系列文章中的第23篇,铂金中的第10篇. 说起ThreadLocal,相信你对它的名字一定不陌生.在并发编程中,它有着较高的出场率,并且也是面试中的高频面试题之一,所以其重要性不言而喻.当然,它也可能曾经让你在夜里辗转反侧,或让你在面试时闪烁其词.因为,ThreadLocal虽然使用简单,但要理解它的原理又似乎并不容易. 然而,正所谓明知山有虎,偏向虎山行.在本文中,我将和你一起学习ThreadLocal的用法及其原理,啃下这块硬骨头. 关于ThreadLoca…
欢迎来到<并发王者课>,本文是该系列文章中的第22篇,铂金中的第9篇. 在前面的文章中,我们已经介绍了ReentrantLock,CountDownLatch,CyclicBarrier,Semaphore等同步工具.在本文中,将为你介绍最后一个同步工具,即Exchanger. Exchanger用于两个线程在某个节点时进行数据交换.在用法上,Exchanger并不复杂,但是实现上会稍微有点费解.所以,考虑到Exchanger在平时使用的场景并不多,况且多数读者对一些"枯燥"…
欢迎来到<并发王者课>,本文是该系列文章中的第14篇. 在黄金系列中,我们介绍了并发中一些问题,比如死锁.活锁.线程饥饿等问题.在并发编程中,这些问题无疑都是需要解决的.所以,在铂金系列文章中,我们会从并发中的问题出发,探索Java所提供的锁的能力以及它们是如何解决这些问题的. 作为铂金系列文章的第一篇,我们将从Lock接口开始介绍,因为它是Java中锁的基础,也是并发能力的基础. 一.理解Java中锁的基础:Lock接口 在青铜系列文章中,我们介绍了通过synchronized关键字实现对方…
欢迎来到<[并发王者课](https://juejin.cn/post/6967277362455150628)>,本文是该系列文章中的**第19篇**. 在上一篇文章中,我们介绍了阻塞队列.如果你阅读过它的源码,那么你一定会注意到源码有两个Condition类型的变量:`notEmpty`和`notFull`,在读写队列时你也会注意到它们是如何被使用的.事实上,在使用JUC中的各种锁时,Condition都很有用场,你很有必要了解它.所以,本文就为你介绍它的来龙去脉和用法. 在前面的系列文章…
欢迎来到<并发王者课>,本文是该系列文章中的第21篇,铂金中的第8篇. 在上一篇文章中,我们介绍了CountDownLatch的用法.在协调多线程的开始和结束时,CountDownLatch是个非常不错的选择.而本文即将给你介绍的CyclicBarrier则更加有趣,它在能力上和CountDownLatch既有相似之处,又有着明显的不同,值得你一览究竟.本文会先从场景上带你理解问题,再去理解CyclicBarrier提供的方案. 一.CyclicBarrier初体验 1. 峡谷森林里的爱情 在…
欢迎来到<并发王者课>,本文是该系列文章中的第15篇. 在上篇文章中,我们介绍了Java中锁的基础Lock接口.在本文中,我们将介绍Java中锁的另外一个重要的基本型接口,即ReadWriteLock接口. 在探索Java中的并发时,ReadWriteLock无疑是重要的,然而理解它却并不容易.如果你此前曾经检索资料,应该会发现大部分的文章对它的描述都比较晦涩难懂,或连篇累牍的源码陈列,或隔靴搔痒的三言两语,既说不到重点,也说不清来龙去脉. 所以,在本文中我们会将介绍的重点放在对思路的理解上,…
在前面的文章<双刃剑-理解多线程带来的安全问题>中,我们提到了多线程情况下存在的线程安全问题.本文将以这个问题为背景,介绍如何通过使用synchronized关键字解这一问题.当然,在青铜阶段,我们仍不会过多地描述其背后的原理,重点还是先体验并理解它的用法. 一.从场景中体验synchronized 是谁击败了主宰 在峡谷中,击败主宰可以获得高额的经济收益.因此,在条件允许的情况下,大家都会争相击败主宰.于是,哪吒和敌方的兰陵王开始争夺主宰.按规矩,谁是击败主宰的最后一击,谁便是胜利的一方.…
在前面的<兵分三路:如何创建多线程>文章中,我们已经通过Thread和Runnable直观地了解如何在Java中创建一个线程,相信你已经有了一定的体感.在本篇文章中,我们将基于前面的示例代码,对线程做些必要的说明,以帮助你从更基础的层面认知线程,并为后续的学习打下基础. 一.从进程认知线程 在上世纪的80年代中期之前,进程一直都是操作系统中拥有资源和独立运行的基本单位.可是,随着计算机的发展,人们对操作系统的吞吐量要求越来越高,并且多处理器也逐渐发展起来,进程作为基本的调度单位已经越来越不合时…
在前面的文章<青铜4:synchronized用法初体验>中,我们已经提到锁的概念,并指出synchronized是锁机制的一种实现.可是,这么说未免太过抽象,你可能无法直观地理解锁究竟是什么?所以,本文会粗略地介绍synchronized背后的一些基本原理,让你对Java中的锁有个粗略但直观的印象. 本文将分两个部分,首先你要从Mark Word中认识锁,因为对象锁的信息存在于Mark Word中,其次通过JOL工具实际体验Mark Word的变化. 一.从Mark Word认识锁 我们知道…
在前面的文章中,我们已经体验过synchronized的用法,并对锁的概念和原理做了简单的介绍.然而,你可能已经察觉到,有一个概念似乎总是和synchronized.锁这两个概念如影相随,很多人也比较喜欢问它们之间的区别,这个概念就是Monitor,也叫监视器. 所以,在讲解完synchronized.锁之后,文本将为你讲解Monitor,揭示它们之间那些公开的秘密,希望你不再迷惑. 首先,你要明白的是,Monitor作为一种同步机制,它并非Java所特有,但Java实现了这一机制. 为了具象地…
转载:http://www.cnblogs.com/dolphin0520/p/3920407.html 一. 对ThreadLocal的理解 ThreadLocal,很多地方叫做线程本地变量,也有地方叫做线程本地存储,其实意思差不多.可能很多朋友都知道ThreadLocal为变量在每个线程中都创建了一个副本,那么每个线程可以访问自己内部的副本变量. 这句话从字面上看起来看容易理解,但真正理解并不是那么容易. /** * 学习ThreadLocal * Created by mrf on 201…
一.目录      1.ThreadLocal是什么?有什么用?      2.ThreadLocal源码简要总结?      3.ThreadLocal为什么会导致内存泄漏? 二.ThreadLocal是什么?有什么用? 引入话题:在并发条件下,如何正确获得共享数据?举例:假设有多个用户需要获取用户信息,一个线程对应一个用户.在mybatis中,session用于操作数据库,那么设置.获取操作分别是session.set().session.get(),如何保证每个线程都能正确操作达到想要的结…
本文将主要结合源码讲述 ThreadLocal 的使用场景和内部结构,以及 ThreadLocalMap 的内部结构:另外在阅读文本之前只好先了解一下引用和 HashMap 的相关知识,可以参考 Reference 框架概览.Reference 完全解读.HashMap 相关: 一.使用场景 通常情况下避免多线程问题有三种方法: 不使用共享状态变量: 状态变量为不可变的: 访问共享变量时使用同步: 而 ThreadLocal 则是通过每个线程独享状态变量的方式,即不使用共享状态变量,来消除多线程…
在jdk中,为并发编程提供了CyclicBarrier(栅栏),CountDownLatch(闭锁),Semaphore(信号量),Exchanger(数据交换)等工具类,我们在前面的学习中已经学习并分析了CountDownLatch工具类的使用方式和源码实现,接下来我们继续学习CyclicBarrier,Semaphore,Exchanger的源码实现. 1. CyclicBarrier(栅栏) 1.1 CyclicBarrier的使用方式 在实际的并发中,我们可能需要等待所有线程到达一个数量…
死锁 经典的死锁:哲学家进餐问题.5个哲学家 5个筷子 如果没有哲学家都占了一个筷子 互相等待筷子 陷入死锁 数据库设计系统中一般有死锁检测,通过在表示等待关系的有向图中搜索循环来实现. JVM没有死锁检测. 锁顺序死锁 典型的列子:LeftRightDeadLock,多个线程尝试去获取左右的锁.这个和哲学家吃饭的两个筷子类似. 下面的转账锁顺序死锁: public class DynamicOrderDeadlock {    public static void transferMoney(…
高并发大流量专题---10.MySQL数据库层的优化 一.总结 一句话总结: mysql先考虑做分布式缓存,过了缓存后就做mysql数据库层面的优化 1.mysql数据库层的优化的前面一层是什么? 数据库缓存:突破了数据库缓存就需要做mysql数据库层的优化 2.mysql优化方向? 数据表数据类型优化:索引优化:SQL语句的优化 存储引擎的优化 数据表结构设计的优化 数据库服务器架构的优化 3.mysql数据表的数据类型优化考虑? 合适:字段使用什么样的数据类型更合适 更快:字段使用什么样的数…
ThreadLocal的作用 从上一篇对于ThreadLocal的分析来看,可以得出结论:ThreadLocal不是用来解决共享对象的多线程访问问题的,通过ThreadLocal的set()方法设置到线程的ThreadLocal.ThreadLocalMap里的是是线程自己要存储的对象,其他线程不需要去访问,也是访问不到的.各个线程中的ThreadLocal.ThreadLocalMap以及ThreadLocal.ThreadLocal中的值都是不同的对象. 至于为什么要使用ThreadLoca…
从名字上看,『ThreadLocal』可能会给你一种本地线程的概念印象,可能会让你联想到它是一个特殊的线程. 但实际上,『ThreadLocal』却营造了一种「线程本地变量」的概念,也就是说,同一个变量在每个线程的内部,都有一份副本,且相互之间具有不同的取值. 这样的设计具有怎样的应用场景呢?是怎么样的一种设计原理呢? 别急,本篇就来详细的探讨探讨它. 基本介绍 上面我们粗略的介绍了「什么是 ThreadLocal ?」的这个问题,下面我们来看看它的一个基本使用是什么样的,以及设计出来旨在解决什…
进程 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础.程序是指令.数据及其组织形式的描述,进程是程序的实体. 进程具有的特征: 动态性:进程是程序的一次执行过程,是临时的,有生命期的,是动态产生,动态消亡的 并发性:任何进程都可以同其他进行一起并发执行 独立性:进程是系统进行资源分配和调度的一个独立单位 结构性:进程由程序,数据和进程控制块三部分组成 我们经常使用windows系统,经常会看见.exe后缀的文件,双击…
ThreadLocal类可以理解成一个类似与map集合使用,以当前线程当做key 来使用,将线程氛围内需要共享的数据当做value,形成键值对的形式使用.ThreadLocal和线程同步机制都是为了解决多线程中对同一个变量的访问冲突问题. 在同步机制中,通过对象的锁机制保证同一时间只有一个线程访问变量.这时该变量是多个线程共享的,使用同步机制要求程序慎密地分析什么时候对变量进行读写,什么时候需要锁定某个对象,什么时候释放对象锁等繁杂的问题,程序设计和编写难度相对较大.而ThreadLocal则从…
SimpleDateFormat在多线程情况下会出现线程不安全的情况,故用ThreadLoacl 处理/** * 用ThreadLocal处理simplDateFormat线程不安全 */public class DateUtil { public static SimpleDateFormat renderSimpleDateFormat(String pattern) { ThreadLocal<SimpleDateFormat> threadLocal = new ThreadLocal…
10分钟教你用python打造贪吃蛇超详细教程 在家闲着没妹子约, 刚好最近又学了一下python,听说pygame挺好玩的.今天就在家研究一下, 弄了个贪吃蛇出来.希望大家喜欢. 先看程序效果: 01 整体框架 平台:pycharm 关于pygame的安装这里就不在赘述,大家自行上网找合适自己的版本的安装即可.关于pygame模块知识会穿插在下面代码中介绍,用到什么就介绍什么.这里就不统一介绍了. 整个程序由于是调用了大量的pygame里面的库函数,所以也非常简单(卧槽你这不是调包侠嘛).也就…
Synchronized用于线程间的数据共享,而ThreadLocal则用于线程间的数据隔离.…
Python并发编程04 /多线程.生产消费者模型.线程进程对比.线程的方法.线程join.守护线程.线程互斥锁 目录 Python并发编程04 /多线程.生产消费者模型.线程进程对比.线程的方法.线程join.守护线程.线程互斥锁 1. 生产消费者模型 2. 线程的理论知识 3. 开启线程的两种方式 4. 线程.进程对比代码验证 5. 线程的其他方法 6. 线程join 7. 守护线程 8. 线程互斥锁 1. 生产消费者模型 定义:编程思想,模型,设计模式,理论等等,都是一种编程的方法,遇到类…
JDBCToolsV2:     利用ThreadLocal保证当前线程操作同一个数据库连接对象. package com.dgd.test; import com.alibaba.druid.pool.DruidDataSourceFactory; import javax.sql.DataSource; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException; im…
Filter(过滤器) Filter过滤器它的作用是:拦截请求,过滤响应. 过滤器链 1)执行的顺序依次是: A B C Demo03 C2 B2 A2 2)如果采取的是注解的方式进行配置,那么过滤器链的拦截顺序是按照全类名的先后顺序排序的 @WebFilter("*.do") 3)如果采取的是xml的方式进行配置,那么按照配置的先后顺序进行排序 精确匹配:<url-pattern>/target.jsp</url-pattern> 目录匹配:<url-p…
java高并发系列第24篇文章. 环境:jdk1.8. 本文内容 需要解决的问题 介绍ThreadLocal 介绍InheritableThreadLocal 需要解决的问题 我们还是以解决问题的方式来引出ThreadLocal.InheritableThreadLocal,这样印象会深刻一些. 目前java开发web系统一般有3层,controller.service.dao,请求到达controller,controller调用service,service调用dao,然后进行处理. 我们写…
linux脚本监控程序运行情况(重启程序)主要有两种情况:一种是一个可执行文件:如shell脚本文件:另一种是使用python打开的多个程序.第一种:它的进程名字由路径名字和程序名字组成,比如:我有个可执行文件,名字为testab.sh,路径是/test输入命令:ps -ef | grep testab.sh | grep -v grep ps -ef | grep testab.sh | grep -v grep 可以看到,当testab.sh执行的时候,grep -v grep  会显示该进…
1.产生随机数 package cn.study.concurrency.ch12; public class Util { public static int xorShift(int y) { //进行左移和无符号右移,最后异或操作(异或,当两个位数据不同的时候为1,否则为0) y ^= (y << 6); y ^= (y >>> 21); y ^= (y << 7); return y;//y初始值是随机种子 } public static void mai…
ThreadLocal是一个容器/集合,是一个Map集合.不管你跨多少层,只要你是同一个线程就可以取出来.Service和Dao是同一个线程.Service第一次调用JdbcUtils.getConnection()方法,把Connection对象装入ThreadLocal容器,当Dao层第二次和第三次调用的时候JdbcUtils.getConnection()方法的时候直接就获取的是ThreadLocal容器里面的Connecton对象.ThreadLocal能够保证的事情是在同一个线程里面拿…