随笔分类 - 多线程
摘要:前言 之前学多线程的时候没有学习线程的同步工具类(辅助类)。ps:当时觉得暂时用不上,认为是挺高深的知识点就没去管了.. 在前几天,朋友发了一篇比较好的Semaphore文章过来,然后在浏览博客的时候又发现面试还会考,那还是挺重要的知识点。于是花了点时间去了解一下。 Java为我们提供了三个同步工具
阅读全文
摘要:1.简介 AbstractQueuedSynchronizer (抽象队列同步器,以下简称 AQS)出现在 JDK 1.5 中,由大师 Doug Lea 所创作。AQS 是很多同步器的基础框架,比如 ReentrantLock、CountDownLatch 和 Semaphore 等都是基于 AQS
阅读全文
摘要:具体可参考:Java并发编程:Thread类的使用,这里对线程状态的转换及主要函数做一下补充。 一. 线程状态转换图 注意: 调用obj.wait()的线程需要先获取obj的monitor,wait()会释放obj的monitor并进入等待态。所以wait()/notify()都要与synchron
阅读全文
摘要:解锁部分,我们将Lua代码传到jedis.eval()方法里,并使参数KEYS[1]赋值为lockKey,ARGV[1]赋值为requestId。eval()方法是将Lua代码交给Redis服务端执行。 那么这段Lua代码的功能是什么呢?其实很简单,首先获取锁对应的value值,检查是否与reque
阅读全文
摘要:废话不多说,直接就开撸import org.springframework.util.StopWatch;import java.util.concurrent.*;/** * 基于线程池实现的多线程卖票demo * joey li * 2018-4-12 * qq: 1914295136 */public class TicketRunnable implements Runna...
阅读全文
摘要:1、可见性(Visibility) 可见性是指,当一个线程修改了某一个全局共享变量的数值,其他线程是否能够知道这个修改。 显然,在串行程序来说可见性的问题是不存在的。因为你在任何一个地方操作修改了某个变量,那么在后续的程序里面,读取这个变量的数值,一定是修改后的数值。 但是,这个问题在并行程序里面就
阅读全文
摘要:版权声明:本文为博主原创文章,未经博主允许不得转载。 http://blog.csdn.net/chenchaofuck1/article/details/51045134 版权声明:本文为博主原创文章,未经博主允许不得转载。 http://blog.csdn.net/chenchaofuck1/a
阅读全文
摘要:在数据库的锁机制中介绍过,数据库管理系统(DBMS)中的并发控制的任务是确保在多个事务同时存取数据库中同一数据时不破坏事务的隔离性和统一性以及数据库的统一性。 悲观锁其实就是 完全同步 比如 synchronized 关键字 或ReentrantLock 乐观锁就是不用同步,用数据库表的一个版本字段
阅读全文
摘要:以下示例均来自jdk concurrent包。/** * 有一个任务,它要等待其他几个任务 * 执行完毕 之后才能执行 * * * 倒计时器 */public class CountDownLatchTest { public static void main(String[] args){ fin
阅读全文
摘要:原作者:海子 原作者:海子 出处:http://www.cnblogs.com/dolphin0520/ 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降
阅读全文