import lombok.extern.slf4j.Slf4j;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit; @Slf4j
public class CountDownLatchExample1 {
private final static int threadCount=200;
public static void main(String[] args) throws Exception{
ExecutorService executorService= Executors.newCachedThreadPool();
final CountDownLatch countDownLatch=new CountDownLatch(threadCount);
for(int i=0;i<threadCount;i++){
final int threadNum=i;
executorService.execute(()->{
try{
test(threadNum);
}catch (Exception e){
log.error("exception",e);
}finally {
countDownLatch.countDown();
}
});
}
//countDownLatch.await(); //保证前面的线程都执行完
countDownLatch.await(10, TimeUnit.MILLISECONDS); //在规定时间内执行
log.info("finish");
}
private static void test(int threadNum) throws Exception{
Thread.sleep(100);
log.info("{}",threadNum);
Thread.sleep(100);
}
}

  

import lombok.extern.slf4j.Slf4j;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Semaphore; @Slf4j
public class SemaphoreExample1 {
private final static int threadCount=20;
public static void main(String[] args) throws Exception{
ExecutorService executorService= Executors.newCachedThreadPool();
final Semaphore semaphore=new Semaphore(3);
for(int i=0;i<threadCount;i++){
final int threadNum=i;
executorService.execute(()->{
try{
if(semaphore.tryAcquire()){ //可以指定执行的时间
test(threadNum);
semaphore.release();
}
//semaphore.acquire(3);//获取多个许可
//semaphore.acquire();//获取一个许可
// test(threadNum);
// semaphore.release();//释放一个许可
//semaphore.release(3);//释放多个许可
}catch (Exception e){
log.error("exception",e);
}
});
} log.info("finish");
}
private static void test(int threadNum) throws Exception{
log.info("{}",threadNum);
Thread.sleep(100);
}
}

  

import lombok.extern.slf4j.Slf4j;
import java.util.concurrent.*; @Slf4j
public class CyclicBarrierExamle1 {
//private static CyclicBarrier barrier=new CyclicBarrier(5);
private static CyclicBarrier barrier=new CyclicBarrier(5,()->{
log.info("callback is running");
});
public static void main(String[] args) throws Exception{
ExecutorService executor= Executors.newCachedThreadPool();
for(int i=0;i<10;i++){
final int threadNum=i;
Thread.sleep(1000);
executor.execute(()->{
try {
race(threadNum);
}catch (Exception e){
log.error("exception",e);
}
});
}
executor.shutdown();
}
private static void race(int threadNum) throws Exception{
Thread.sleep(100);
log.info("{} is ready",threadNum);
//barrier.await();
try {
barrier.await(2000, TimeUnit.MILLISECONDS);
}catch (BrokenBarrierException |TimeoutException e){
log.warn("BrokenBarrierException",e);
} log.info("{}continue",threadNum);
}
}

  

在读取中写入的方法:ReentrantReadWriteLock

线程安全的写法。

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Semaphore;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock; @Slf4j
public class LockExample1 {
//请求总数
public static int clientTotal=5000;
//同时并发执行的线程数
public static int threadTotal=200;
public static int count=0;
private final static Lock lock=new ReentrantLock(); public static void main(String[] args) throws Exception{
ExecutorService executorService= Executors.newCachedThreadPool();
final Semaphore semaphore=new Semaphore(threadTotal);
final CountDownLatch countDownLatch=new CountDownLatch(clientTotal);
for(int i=0;i<clientTotal;i++){
final int count=i;
executorService.execute(()->{
try {
semaphore.acquire();
add(count);
semaphore.release();
}catch (Exception e){
log.error("exception",e);
}
countDownLatch.countDown();
});
}
countDownLatch.await();
executorService.shutdown();
log.info("size{}",count);
}
private static void add(int i){
lock.lock();
try {
count++;
}finally {
lock.unlock();
}
}
}

  

import lombok.extern.slf4j.Slf4j;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantReadWriteLock; @Slf4j
public class LockExample2 {
private final Map<String, Data> map=new TreeMap<>();
private final ReentrantReadWriteLock lock=new ReentrantReadWriteLock();
private final Lock readLock=lock.readLock();
private final Lock writeLock=lock.writeLock();
public Data get(String key){
readLock.lock();
try {
return map.get(key);
}finally {
readLock.unlock();
}
}
public Set<String> getAllKeys(){
readLock.lock();
try {
return map.keySet();
}finally {
readLock.unlock();
}
}
public Data put(String key, Data value){
writeLock.lock();
try {
return map.put(key, value);
}finally {
readLock.unlock();
}
}
class Data{ }
}

  

import lombok.extern.slf4j.Slf4j;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Semaphore;
import java.util.concurrent.locks.StampedLock; @Slf4j
public class LockExample5 {
//请求总数
public static int clientTotal=5000;
//同时并发执行的线程数
public static int threadTotal=200;
public static int count=0;
private final static StampedLock lock=new StampedLock(); public static void main(String[] args) throws Exception{
ExecutorService executorService= Executors.newCachedThreadPool();
final Semaphore semaphore=new Semaphore(threadTotal);
final CountDownLatch countDownLatch=new CountDownLatch(clientTotal);
for(int i=0;i<clientTotal;i++){
final int count=i;
executorService.execute(()->{
try {
semaphore.acquire();
add(count);
semaphore.release();
}catch (Exception e){
log.error("exception",e);
}
countDownLatch.countDown();
});
}
countDownLatch.await();
executorService.shutdown();
log.info("size{}",count);
}
private static void add(int i){
long stamp= lock.writeLock();
try {
count++;
}finally {
lock.unlock(stamp);
}
}
}

  

import java.util.concurrent.locks.StampedLock;
public class LockExample4 {
class Point{
private double x,y;
private final StampedLock sl=new StampedLock();
void move(double deltaX,double deltaY){
long stamp=sl.writeLock();
try{
x+=deltaX;
y+=deltaY;
}finally {
sl.unlockWrite(stamp);
}
} //乐观锁案例
double distanceFromOrigin(){
long stamp=sl.tryOptimisticRead();//获得一个乐观读锁
double currentX=x,currentY=y;//将两个字段读入本地局部变量
if(!sl.validate(stamp)){ //检查发出乐观锁后同时是否有其他锁发生
stamp=sl.readLock();//没有,再次获取一个读悲观锁
try{
currentX=x; //将两个字段读入本地局部变量
currentY=y; //将两个字段读入本地局部变量
}finally {
sl.unlockRead(stamp);
}
}
return Math.sqrt(currentX*currentX+currentY*currentY);
} //悲观锁读写案例
void moveIfAtOrigin(double newX,double newY){
long stamp=sl.readLock();
try {
while (x==0.0&&y==0.0){ //循环,检查当前状态是否符合
long ws=sl.tryConvertToWriteLock(stamp);//将读锁转化为写锁
if(ws!=0L){ //确认转为写锁是否成功
stamp=ws; //如果成功,替换票据
x=newX; //进行状态改变
y=newY; //进行状态改变
break;
}else {
sl.unlockRead(stamp);//如果不能成功转化为写锁
stamp=sl.writeLock();//显示直接进行写锁,然后通过循环再试
}
}
}finally {
sl.unlock(stamp);//释放读锁和写锁
}
}
}
}

  

import lombok.extern.slf4j.Slf4j;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;
@Slf4j
public class LockExample6 {
public static void main(String[] args) {
ReentrantLock reentrantLock=new ReentrantLock();
Condition condition=reentrantLock.newCondition();
new Thread(()->{
try {
reentrantLock.lock();
log.info("wait signal");
condition.await();
}catch (InterruptedException e){
e.printStackTrace();
}
log.info("get signal");
reentrantLock.unlock();
}).start(); new Thread(()->{
reentrantLock.lock();
log.info("get lock");
try {
Thread.sleep(300);
}catch (InterruptedException e){
e.printStackTrace();
}
condition.signalAll();
log.info("send signal~");
reentrantLock.unlock();
}).start();
}
}

  

JAVA-AbstractQueuedSynchronizer-AQS的更多相关文章

  1. 4.从AbstractQueuedSynchronizer(AQS)说起(3)——AQS结语

    前两节的内容<2.从AbstractQueuedSynchronizer(AQS)说起(1)——独占模式的锁获取与释放> .<3.从AbstractQueuedSynchronize ...

  2. 9.深入理解AbstractQueuedSynchronizer(AQS)

    1. AQS简介 在上一篇文章中我们对lock和AbstractQueuedSynchronizer(AQS)有了初步的认识.在同步组件的实现中,AQS是核心部分,同步组件的实现者通过使用AQS提供的 ...

  3. [Java并发] AQS抽象队列同步器源码解析--锁获取过程

    要深入了解java并发知识,AbstractQueuedSynchronizer(AQS)是必须要拿出来深入学习的,AQS可以说是贯穿了整个JUC并发包,例如ReentrantLock,CountDo ...

  4. 深入理解AbstractQueuedSynchronizer(AQS)

    本人免费整理了Java高级资料,涵盖了Java.Redis.MongoDB.MySQL.Zookeeper.Spring Cloud.Dubbo高并发分布式等教程,一共30G,需要自己领取.传送门:h ...

  5. Java:AQS 小记-2(ReentrantLock)

    Java:AQS 小记-2(ReentrantLock) 整体结构 ReentrantLock 类图 AbstractOwnableSynchronizer 类 public abstract cla ...

  6. Java:AQS 小记-1(概述)

    Java:AQS 小记-1(概述) 概述 全称是 Abstract Queued Synchronizer(抽象队列同步器),是阻塞式锁和相关的同步器工具的框架,这个类在 java.util.conc ...

  7. [Java并发] AQS抽象队列同步器源码解析--独占锁释放过程

    [Java并发] AQS抽象队列同步器源码解析--独占锁获取过程 上一篇已经讲解了AQS独占锁的获取过程,接下来就是对AQS独占锁的释放过程进行详细的分析说明,废话不多说,直接进入正文... 锁释放入 ...

  8. 同步类的基础AbstractQueuedSynchronizer(AQS)

    同步类的基础AbstractQueuedSynchronizer(AQS) 我们之前介绍了很多同步类,比如ReentrantLock,Semaphore, CountDownLatch, Reentr ...

  9. 全网最详细的AbstractQueuedSynchronizer(AQS)源码剖析(二)资源的获取和释放

    上期的<全网最详细的AbstractQueuedSynchronizer(AQS)源码剖析(一)AQS基础>中介绍了什么是AQS,以及AQS的基本结构.有了这些概念做铺垫之后,我们就可以正 ...

  10. Java并发框架AbstractQueuedSynchronizer(AQS)

    1.前言 本文介绍一下Java并发框架AQS,这是大神Doug Lea在JDK5的时候设计的一个抽象类,主要用于并发方面,功能强大.在新增的并发包中,很多工具类都能看到这个的影子,比如:CountDo ...

随机推荐

  1. SpringBoot:使用Jenkins自动部署SpringBoot项目(一)环境准备

    1.安装JDK 1.在java官网下载linux下的安装包,上传到云服务器 /user/java 目录下 2.解压:tar xzvf jdk-8u161-linux-x64.tar.gz 3.为了好看 ...

  2. [已解决] Python logging 重复打印日志信息

    问题描述 问题代码如下: def get_logger(logger_name): """得到日志对象""" logger = loggin ...

  3. 【BigData】Java基础_冒泡排序

    1.实现需求 根据已经存在的数组,使用冒泡排序将数组中的元素排序后输出. 2.代码 package cn.test.logan.day02; /** * 冒泡排序在数组上的实现 * @author Q ...

  4. jenkins使用--安装文档

    添加Jenkins的源(repository): #sudo wget -O /etc/yum.repos.d/jenkins.repo http://jenkins-ci.org/redhat/je ...

  5. [Gamma阶段]第四次Scrum Meeting

    Scrum Meeting博客目录 [Gamma阶段]第四次Scrum Meeting 基本信息 名称 时间 地点 时长 第四次Scrum Meeting 19/05/30 大运村寝室6楼 35min ...

  6. 转载:【TP5.0】TP5 Validate 验证规则

    下面是部分tp5内置的验证规则: 格式验证类: 'name'=>'require' 验证某个字段的值是否为数字(采用filter_var验证),例如: number 或者 integer 'na ...

  7. 使用gevent包实现concurrent.futures.executor 相同的公有方法。组成鸭子类

    类名不同,但公有方法的名字和提供的基本功能大致相同,但两个类没有共同继承的祖先或者抽象类 接口来规定他,叫鸭子类. 使并发核心池能够在 threadpoolexetor和geventpoolexecu ...

  8. promise简单实现

    function isFunction(fn){ return Object.prototype.toString.call(fn) === '[object Function]'; } let ST ...

  9. 【452】pandas筛选出表中满足另一个表所有条件的数据

    参考:pandas筛选出表中满足另一个表所有条件的数据 参考:pandas:匹配两个dataframe 使用 pd.merge 来实现 on 表示查询的 columns,如果都有 id,那么这是很好的 ...

  10. ireport5.6.0分组显示

    一,ireport中分组 二,java调用实现分组 一,ireport中分组: 1,新建模板文件,纸张随意,名称随意,路径随意 2,连接要分组的数据源 3,添加测试表和数据 CREATE TABLE ...