Java多线程编程-生产者,消费者
2016-04-28 21:22
441 查看
来个生产者消费者的事例。
(1)几个同步方法的说明:
(2)Lock和synchronized区别:
执行结果;
说明:利用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(); } } } } }
执行结果;
相关文章推荐
- Java基础
- 有关Java继承的一小段代码
- java类型转换
- 19、JavaBean、MVC
- java Scanner nextLine next 连用的区别
- Java volatile 关键字
- JAVA实验 多线程的使用
- Java编程中“为了性能”一些尽量做到的地方
- Java中列表的排序
- Java中包装器类的作用
- 针对初学者了解JVM、JRE和JDK三者间的区别和联系
- Quartz Spring与Spring Task总结
- java并发编程(2)--Thread类的使用
- java设计模式-抽象工厂模式
- java类的初始化
- java--接口和内部类
- Java实现FTP上传下载功能
- eclipse cdt: import existing projects
- 配置java环境变量
- 【排序算法】希尔排序(java实现)