消费者和生产者模式 用继承Thread方式,用wait和notifyAll方法实现. 消费者和生产者模式的特点 1. 什么时候生产:仓库没有满的时候,生产者这可以生产,消费者也可以消费,仓库满的时候停止生产 2. 什么时候消费: 仓库有货的时候消费,没有货不能消费 3. 通知生产:消费者发现没有货,消费者通知生产者生产 4. 通知消费:生产者生产出产品后,通知消费者消费 代码实现 package com.java.javabase.thread.base; import lombok.AllAr…
/* * 多线程-消费者和生产者模式 * 在实现消费者生产者模式的时候必须要具备两个前提,一是,必须访问的是一个共享资源,二是必须要有线程锁,且锁的是同一个对象 * */ /*资源类中定义了name(名字):用来区分消费者还是生产者 * 定义了flag标记:用来区分有没有货物(默认生产一个就要消费一个) * 定义了count(生产的个数统计) * set方法:用来生产商品 * out方法:用来消费商品*/ class TestSource{ private String name=null; p…
一.springcloud 实现简单的 消费者和生产者 模式(Restfule 的风格) 1.实现简单的消费者和生产者 springcloud使用的http协议进行传输数据,也就是说springcloud仍然使用的是RESTFUL的风格 1.1.搭建工程(!!!springboot的项目是否需要运行都打jar包!!!(springboot工程中不需要war包)) 搭建一个总的父级工程 20190926-springcloud-parent(pom):只做jar包的管理 把SRC 目录干掉 //…
java并发初探ConcurrentSkipListMap ConcurrentSkipListMap以调表这种数据结构以空间换时间获得效率,通过volatile和CAS操作保证线程安全,而且它保证了有序性,比TreeMap比线程安全. 跳表结构 通过level down right可以更快插入和查找元素 * * Head nodes Index nodes * +-+ right +-+ +-+ * |2|---------------->| |--------------------->|…
java并发初探ConcurrentHashMap Doug Lea在java并发上创造了不可磨灭的功劳,ConcurrentHashMap体现这位大师的非凡能力. 1.8中ConcurrentHashMap的线程安全 1.volatile Node<k,v> []table保证数组的可见性 2.get操作没有加锁 3.put操作调用final V putVal(K key, V value, boolean onlyIfAbsent) ,在方法内部为Syncronized方法加锁,Syncr…
java并发初探ThreadPoolExecutor拒绝策略 ThreadPoolExecuter构造器 corePoolSize是核心线程池,就是常驻线程池数量: maximumPoolSize是最大线程池数量,如果队列满了,就会创建新的线程任务.如果与corePoolSize一样大小, 那么就是固定大小的鹅线程池: keepAliveTime表示线程池中线程空闲时间,当空闲时间达到keepAliveTime,线程会被销毁,直到剩下corePoolSize, 默认情况只有当前的线程数大于cor…
java并发初探CyclicBarrier CyclicBarrier的作用 CyclicBarrier,"循环屏障"的作用就是一系列的线程等待直至达到屏障的"瓶颈点". 具体的使用就是就是一些列的线程调用CyclicBarrier得await()方法进入等待,直至达到 CyclicBarrier设置的barrier size,其他的线程会继续运行. /** * A synchronization aid that allows a set of threads t…
java并发初探CountDownLatch CountDownLatch是同步工具类能够允许一个或者多个线程等待直到其他线程完成操作. 当前前程A调用CountDownLatch的await方法进入阻塞(LockSupportd的park方法), 其他线程调用CountDownLatch调用countDown(),CountDownLatch的内部变量 count为零时,线程A唤醒. * A synchronization aid that allows one or more threads…
java并发初探ReentrantWriteReadLock ReenWriteReadLock类的优秀博客 ReentrantReadWriteLock读写锁详解 Java多线程系列--"JUC锁"08之 共享锁和ReentrantReadWriteLock ReentrantWriteReadLock类实现 @startuml interface Lock interface ReadWriteLock class ReentrantReadWriteLock{ Sync sync…
题目要求 用java代码模拟实现:一个人不断往箱子里放苹果,另一个人不断从箱子里取苹果,箱子只能放5个苹果,苹果数量无限.要求不使用java.util.concurrent包中的类. 思路 这道题主要考,java并发编程.Object.wai().Object.notify()方法的使用.循环队列的使用 1.使用两个线程分别模拟放苹果和取苹果. 2.定义一个类放苹果,类里主要是对一个数组的封装 注意: Object.wait()及Object.notify()方法的使用,下面是摘自JDK1.6文…