Java多线程编程-生产者,消费者
来源:互联网 发布:淘宝争议处理规范规则 编辑:程序博客网 时间:2024/04/29 14:49
来个生产者消费者的事例。
说明:利用Object的wait(),notify()或者notifyAll()进行生产者和消费者的同步。
(1)几个同步方法的说明:
wait()会释放CPU和对象锁,notify()用来唤醒因为使用了wait()方法而等待的线程(等待同一对象的线程)。而sleep(time)只会释放CPU而不会释放对向锁
(2)Lock和synchronized区别:
synchronized是基于JVM的,Lock是JDK1.5以后用代码实现的。在并发量不是很大的情况下,优先使用synchronized。但是一旦并发量很大的时候,synchronized会效率低下,这时就得使用Lock,此时Lock的效率会高出很多。 Lock在synchronized的基础上添加了超时等待锁,打断等待锁的机制。超时等待锁就是一个等待锁的线程在等待了一定的时间后,将不会等待而去执行其它事情。而synchronized等待锁的时候是不会被打断的。 synchronized是使用悲观所机制,即线程会使用阻塞的方式等待锁,线程阻塞会保持线程的上下文,大量的阻塞会降低CPU效率。而Lock是使用乐观所机制。它不会真正的阻塞,而是不断的尝试获取锁,直到成功获取锁。是使用compareAndSet()方法,是使用CPU的内部指令。所以高并发的情况下,Lock效率会更高。
public class Main { public static Object oj=new Object(); public static void main(String[] args) { // TODO Auto-generated method stub Thread pro=new Thread(new Producer()); pro.start(); Thread com=new Thread(new Comsumer()); com.start(); }}//生产者class Producer implements Runnable{ @Override public void run() { int count=0; while(count<5){ synchronized (Main.oj) { System.out.println("生产者"+count); count++; Main.oj.notify(); try { Main.oj.wait(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }}//消费者class Comsumer implements Runnable{ @Override public void run() { int count=0; while(count<5){ synchronized (Main.oj) { System.out.println("消费者"+count); count++; Main.oj.notify(); try { Main.oj.wait(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }}
执行结果;
0 0
- Java多线程编程-生产者,消费者
- 多线程编程之生产者消费者(java实现)
- java多线程 消费者-生产者
- java多线程 消费者-生产者
- java 多线程 生产者消费者
- JAVA [ 多线程 -- 生产者消费者 ]
- Java 多线程-生产者、消费者
- java多线程--生产者消费者
- java多线程-生产者消费者
- Java多线程生产者消费者
- java多线程-生产者消费者
- 多线程编程之生产者消费者
- 多线程编程:生产者消费者模式
- Java多线程编程中生产者-消费者模式的详解
- Java多线程编程3--线程间通信--生产者/消费者模式
- Java多线程编程核心技术——生产者消费者模型
- Java 多线程编程(生产者和消费者问题以及死锁)
- Java多线程编程中生产者-消费者模式的详解
- 微型Top源码剖析
- 解决sphinx命令行search搜索中文乱码的问题
- Android5.0/6.0新特性
- Hosts---2016.4.28可用goolge hosts
- iOS开发总结之 view的frame、center和和view的bounds之间的区别
- Java多线程编程-生产者,消费者
- Codeforces Round #348 (VK Cup 2016 Round 2, Div. 1 Edition) C 离散化+树状数组+map D 数学
- 【笔试/面试】—— Linux 查看 cpu 和内存使用情况
- 使用腾讯云部署LNMP环境,遇到的问题及解决
- Qt之校验器
- C++ 字符串十六进制与十进制的互转
- 利用js和html实现表单操作(onsubmit、onclick、submit等方法的异同)
- 1010 Problem J
- 纯css,div隐藏滚动条,保留鼠标滚动效果。