美文网首页
JDK并发包零散记录

JDK并发包零散记录

作者: 少寨主的互联网洞察 | 来源:发表于2018-11-12 20:50 被阅读0次

信号量

  • 它的作用是啥?

一般情况下,临界区只允许一个线程进入,而信号量呢则是同一时间允许放入多个线程

来看个demo:

package someTest;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Semaphore;

public class SemapDemo implements Runnable{
    final Semaphore semap=new Semaphore(5);
    @Override
    public void run() {
        try {
            semap.acquire();
            //模拟耗时操作
            Thread.sleep(2000);
            System.out.println(Thread.currentThread().getId()+":done!");
        }catch (InterruptedException e) {
            e.printStackTrace();
        }finally {
            semap.release();
        }
    }
    public static void main(String[] args) {
        ExecutorService exec=Executors.newFixedThreadPool(20);
        final SemapDemo demo=new SemapDemo();
        for(int i=0;i<20;i++) {
            exec.submit(demo);
        }
    }
}

ReadWriteLock

一种读写分离锁
读——读不互斥
读——写互斥
写——写互斥

CountDownLatch

集齐七龙珠,召唤神龙的故事

来看个demo

package someTest;

import java.util.Random;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class CountDownLatchDemo implements Runnable{
    static final CountDownLatch end=new CountDownLatch(10);
    static final CountDownLatchDemo demo=new CountDownLatchDemo();
    @Override
    public void run() {
        try {
            //模拟检查任务
            Thread.sleep(new Random().nextInt(10)*1000);
            System.out.println("check complete");
            end.countDown();
        }catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
    public static void main(String[] args) throws InterruptedException {
        ExecutorService exec=Executors.newFixedThreadPool(10);
        for(int i=0;i<10;i++) {
            exec.submit(demo);
        }
        //等待检查
        end.await();
        //发射火箭
        System.out.println("fire");
        exec.shutdown();
    }
}

输出结果:

check complete
check complete
check complete
check complete
check complete
check complete
check complete
check complete
check complete
check complete
fire

相关文章

  • JDK并发包零散记录

    信号量 它的作用是啥? 一般情况下,临界区只允许一个线程进入,而信号量呢则是同一时间允许放入多个线程 来看个dem...

  • JDK并发包

    java高并发程序设计 - 网易云课堂 一、重入锁 重入锁是synchronized,Object.wait(),...

  • 01_Java面试题_Java 基础

    1.JDK 和 JRE 有什么区别? JDK,开发java程序用的开发包,JDK里面有java的运行环境(JRE)...

  • JDK并发包-JDK并发容器

    除了同步控制,线程池等基本工具以外,JDK还准备了一大批好用的容器类。 1.1 并发集合 JDK提供的这些容器大部...

  • 005_JavaWeb项目部署与Tomcat环境配置

    【任务一】:安装 JDK。 步骤: 双击 JDK 安装文件。 按照提示安装 JDK 到 D 盘,并记录下安装路径,...

  • JDK并发包 - ExecutorCompletionServi

    1. 接口CompletionService 接口CompletionService设计目标在于将生产者和消费者解...

  • JDK并发包 - FutureTask

    1. FutureTask FutureTask实现了Runnable和Future接口,它主要用于包装真实cal...

  • java jdk并发包

    1.ReentrantLock 这个锁的意义相当于一个多线程安全的允许做某些事情的标志位,拥有该标志位则拥有执...

  • java基础-JDK环境搭建

    JDK与JRE JDK(Java Development Kit)称为Java开发包或Java开发工具,是一个编写...

  • J.U.C并发包简介

    J.U.C并发包简介 J.U.C并发包, 即java.util.concurrent包, 是JDK的核心工具包, ...

网友评论

      本文标题:JDK并发包零散记录

      本文链接:https://www.haomeiwen.com/subject/rchcfqtx.html