- 浏览: 178151 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (99)
- 备忘录 (48)
- linux (19)
- oracle (10)
- shell (8)
- awk (1)
- java (48)
- just do it (29)
- more and more (46)
- common (29)
- 设计模式 (8)
- Java Web (9)
- Spring (0)
- Structs 2 (2)
- Java 高级 (4)
- 存储 (3)
- Virtual Box (1)
- ant (1)
- maven (0)
- 数据结构 (5)
- 算法 (5)
- javascript (1)
- ajax (1)
- jquery (1)
- xml (1)
- IBM (3)
- 转载 (3)
- English (2)
- html&css (0)
- hibernate (2)
- mysql (1)
- memcached (1)
最新评论
-
飞出四季做的茧:
kris_zhang 写道int temp = 0 ; ...
Java IO流 Zip文件的压缩和解压缩 -
kris_zhang:
int temp = 0 ; while(( ...
Java IO流 Zip文件的压缩和解压缩 -
welcomezhang:
学习了,这块自己还得深挖下
为什么HashMap不是线程安全的 -
fomeiherz:
这个写的最详细了,赞一个
Java的泛型类和泛型方法 -
beijishiqidu:
hanmiao 写道http://yangguangfu.it ...
Java设计模式之策略模式
闲来无事,好久没有接触Java的高级东西了,害怕后期会忘记而寻找资料无门,所以写一个最简单的并且典型的多线程入门例子
测试类:
打印的结果如下
同步代码块:
1.被synchronized包围的代码块称为同步代码块
2.synchronized代码块需要接收一个参数,该参数是一个对象,可以称为该代码块的锁对象(又称同步锁)。
3.若某线程一旦持有锁对象的监视器,其它线程即不能同时持有该锁对象的监视器,从而实现线程基于特定锁对象的互斥。
4.注意:这里表示的是线程独占锁对象的监视器,而非锁对象,其它线程仍可以访问该锁对象的方法和属性。
5.多个线程以竞争的方式争夺锁对象的监视器,线程执行完该代码块,即释放锁对象的监视器。
同步实例方法:
就是在方法前面加上关键字synchronized,即实现了方法的同步,相当于整个方法是一个同步代码块,其锁对象是this
同步静态方法:
就是在静态方法前面加上关键字synchronized,也是将整个方法看做一个同步代码块,其锁对象较特别,是将所属类作为锁对象
Java提供了一个精心设计的线程间通信机制即wait-notify机制,通过该机制可以实现线程协作,wait-notify机制是通过使用wait()、notify()和notifyAll()三个方法来实现的,这三个方法均定义在Object类中,是final修饰的实例方法,这三个方法必须在synchronized代码中调用,而且只有锁对象才能调用这三个方法。即持有锁对象监视器的线程才能调用锁对象的这三个方法;
wait()方法:
调用该方法的线程退出监视器并进入等待状态,直到其他线程进入相同的监视器并调用notify( )方法。
notify()方法:
通知等待(该方法所属对象)监视器的(多个)线程中的一个结束等待;即唤醒一个等待(当前线程所持有)监视器的线程。
notifyAll()方法:
通知等待(该方法所属对象)监视器的所有线程结束等待;即唤醒所有等待(当前线程所持有)监视器的线程。
后记,还有几个方法没有涉及到,时间有限,后期会慢慢的同步。
/** * * @author Administrator */ public class BigCup { /** * 容器的大小 */ private int size; /** * 容器当前的数量 */ private int count; public BigCup(int i) { this.size = i; } public void push(String name) { System.out.println(name + "放进去一个面包"); count++; } public void pop(String name) { System.out.println(name + "拿出来一个面包"); count--; } public int getSize() { return size; } public void setSize(int size) { this.size = size; } public int getCount() { return count; } public void setCount(int count) { this.count = count; } }
public class Producer implements Runnable { /** * 生产者的名字 */ private String name; /** * 拿着当前容器的引用 */ private BigCup bc; public Producer(String name, BigCup bc) { super(); this.name = name; this.bc = bc; } @Override public void run() { Thread.currentThread().setName(name); //Thread.currentThread().setPriority(1); set(); } @SuppressWarnings("static-access") public void set() { for (int i = 0; i < 100; i++) { synchronized (bc) { while (bc.getCount() >= bc.getSize()) { try { System.out.println("满了,请取东西..."); bc.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } try { Thread.currentThread().sleep(300); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } bc.push(name); bc.notify(); Thread.yield(); } } } public String getName() { return name; } public void setName(String name) { this.name = name; } public BigCup getBc() { return bc; } public void setBc(BigCup bc) { this.bc = bc; } }
public class Consumer implements Runnable { /** * 消费者的名字 */ private String name; /** * 拿着当前容器的引用 */ private BigCup bc; public Consumer(String name, BigCup bc) { super(); this.name = name; this.bc = bc; } @Override public void run() { Thread.currentThread().setName(name); //Thread.currentThread().setPriority(8); get(); } @SuppressWarnings("static-access") public void get() { for (int i = 0; i < 100; i++) { synchronized (bc) { while (bc.getCount() < 1) { try { System.out.println("空了,请放东西..."); bc.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } try { Thread.currentThread().sleep(300); } catch (InterruptedException e) { e.printStackTrace(); } bc.pop(name); bc.notify(); Thread.yield(); } } } public String getName() { return name; } public void setName(String name) { this.name = name; } public BigCup getBc() { return bc; } public void setBc(BigCup bc) { this.bc = bc; } }
测试类:
public class Test { public static void main(String[] args) { BigCup bc = new BigCup(10); Consumer c = new Consumer("旺旺", bc); Producer p = new Producer("淘宝", bc); Thread t1 = new Thread(p); t1.start(); Thread t2 = new Thread(c); t2.start(); Thread t3 = new Thread(c); t3.start(); Thread t4 = new Thread(c); t4.start(); Thread t5 = new Thread(c); t5.start(); } }
打印的结果如下
空了,请放东西... 空了,请放东西... 淘宝放进去一个面包 旺旺拿出来一个面包 空了,请放东西... 空了,请放东西... 淘宝放进去一个面包 淘宝放进去一个面包 淘宝放进去一个面包 满了,请取东西... 旺旺拿出来一个面包 旺旺拿出来一个面包 旺旺拿出来一个面包 空了,请放东西... 空了,请放东西... 淘宝放进去一个面包 淘宝放进去一个面包 旺旺拿出来一个面包 旺旺拿出来一个面包 空了,请放东西... 空了,请放东西...
同步代码块:
1.被synchronized包围的代码块称为同步代码块
2.synchronized代码块需要接收一个参数,该参数是一个对象,可以称为该代码块的锁对象(又称同步锁)。
3.若某线程一旦持有锁对象的监视器,其它线程即不能同时持有该锁对象的监视器,从而实现线程基于特定锁对象的互斥。
4.注意:这里表示的是线程独占锁对象的监视器,而非锁对象,其它线程仍可以访问该锁对象的方法和属性。
5.多个线程以竞争的方式争夺锁对象的监视器,线程执行完该代码块,即释放锁对象的监视器。
同步实例方法:
就是在方法前面加上关键字synchronized,即实现了方法的同步,相当于整个方法是一个同步代码块,其锁对象是this
同步静态方法:
就是在静态方法前面加上关键字synchronized,也是将整个方法看做一个同步代码块,其锁对象较特别,是将所属类作为锁对象
Java提供了一个精心设计的线程间通信机制即wait-notify机制,通过该机制可以实现线程协作,wait-notify机制是通过使用wait()、notify()和notifyAll()三个方法来实现的,这三个方法均定义在Object类中,是final修饰的实例方法,这三个方法必须在synchronized代码中调用,而且只有锁对象才能调用这三个方法。即持有锁对象监视器的线程才能调用锁对象的这三个方法;
wait()方法:
调用该方法的线程退出监视器并进入等待状态,直到其他线程进入相同的监视器并调用notify( )方法。
notify()方法:
通知等待(该方法所属对象)监视器的(多个)线程中的一个结束等待;即唤醒一个等待(当前线程所持有)监视器的线程。
notifyAll()方法:
通知等待(该方法所属对象)监视器的所有线程结束等待;即唤醒所有等待(当前线程所持有)监视器的线程。
后记,还有几个方法没有涉及到,时间有限,后期会慢慢的同步。
发表评论
-
为什么HashMap不是线程安全的
2016-06-15 22:27 2217序 最近因为项目的需求,经常会面试一些新人,也就会问他们 ... -
JAVA读取文件夹大小的几种方法实例
2016-04-24 15:39 718总是发现自己的C盘快满了,清理程序也不会帮我自己清理,然后 ... -
Java Regex - Matcher (java.util.regex.Matcher)
2015-03-01 13:59 861The Java Matcher class (java. ... -
Java Regex - Pattern (java.util.regex.Pattern)
2015-03-01 11:22 1536Java中的Pattern类是Java正则表达式API ... -
eclipse中查看jdk的源码
2014-11-23 11:43 1020最近一段时间跟jdk源码打交道的比较多,但是有的时候却是看 ... -
Struts2学习初设系列(一)之环境搭建
2014-07-20 22:47 1074已经毕业很长时间了,回过头来想想都不知道自己做了什么,由于 ... -
算法的时间复杂度分析
2014-07-20 11:14 16512.9.1 算法时间复杂度定义 在进 ... -
解析 Java 类和对象的初始化过程
2014-07-06 18:14 652问题引入 近日我在调试一个枚举类型的解析器程序,该 ... -
Java 中正确使用 hashCode 和 equals 方法
2014-07-05 18:17 648在这篇文章中,我将告诉大家我对hashCode和equals ... -
通过分析 JDK 源代码研究 Hash 存储机制
2014-07-05 17:22 611集合和引用 就像引 ... -
NIO 入门
2014-07-05 17:15 642在开始之前 关于本教程 新的输入/输出 (NIO) 库 ... -
利用AJax方式提交和Webservice完成页面输入汉字简体字回显繁体字
2014-06-29 18:05 1140最近一直在学习新的 ... -
How To Parse XML File Using XPath In Java
2014-06-29 11:59 1304最近一直在学习XML的Xpath解析方式,据说是一个很简单 ... -
Java排序算法之快速排序
2014-06-22 11:27 805快速排序使用分治法(Divide and conquer)策略 ... -
Java排序算法之简单选择排序
2014-06-21 22:31 766在网上搜索了很多的算法,貌似大家说的简单选择排序算法和直接选择 ... -
Java排序算法之冒泡排序
2014-06-21 20:22 989冒泡排序算法的基本思想是:首先将第n-1个记录的关键字和第n个 ... -
Java排序算法之直接插入排序
2014-06-21 19:33 1183直接插入排序算法的基本思想是:把n个待排序的元素看成为 ... -
JAVA之桥接模式
2014-05-26 20:11 0桥模式:将某个问题抽象的不同形式分别与该问题的具体实现 ... -
Java数字小写转换为大写
2014-05-11 11:52 1401闲来无事,在网上搜索了一些面试的题目,开始练习下,下列代码的作 ... -
Oracle SQL developer 报JVM错误解决和更换jdk
2014-05-03 20:35 0今日升级 Oracle SQL developer为2.1。发 ...
相关推荐
Java多线程--生产者与消费者问题
java多线程实现生产者和消费者
编写一个“生产者-消费者”的多线程演示程序,两个生产者,一个消费者,可以存放产品的仓库容量为10,仓库用栈实现,并有同步功能,且能防止先消费后生产的情况。
java多线程经典模型生产者消费者java多线程经典模型生产者消费者java多线程经典模型生产者消费者java多线程经典模型生产者消费者java多线程经典模型生产者消费者java多线程经典模型生产者消费者java多线程经典模型...
生产者-消费者实例可以很好帮助初学java的同学们理解和学习多线程的知识
【IT十八掌徐培成】Java基础第08天-04.多线程-生产者-消费者.zip
【IT十八掌徐培成】Java基础第08天-05.多线程-生产者-消费者2.zip
java多线程实现生产者消费者关系,完成线程之间的同步。
java实现多线程经典模型生产者消费java实现多线程经典模型生产者消费java实现多线程经典模型生产者消费java实现多线程经典模型生产者消费java实现多线程经典模型生产者消费java实现多线程经典模型生产者消费java实现...
生产者消费者模式是java多线程经典的安全,它用到了同步,资源共享,wait,notify等技术。
用java多线程,实现生产者消费者同步和互斥的问题,操作系统中的经典问题
使用一个共享队列,生产者把产品放入队列,消费者消费产品,实现简单的多线程示例.
用java多线程简易实现生产者消费者模式的代码,用java多线程简易实现生产者消费者模式的代码。
基本满足操作系统课上要求,java实现的生产者消费者模型。
NULL 博文链接:https://hbkh2000.iteye.com/blog/378843
利用线程间的通信主要是因为当多个线程同时对一个对象进行访问的时候,多个线程之间是一个协助的关系,举个例子就是今天要说的生产这和消费者模型。
本代码是用JAVA实现的生产者与消费者的问题,线程间的同步与互斥功能
Java线程:并发协作-生产者消费者模型 Java线程:并发协作-死锁 Java线程:volatile关键字 Java线程:新特征-线程池 Java线程:新特征-有返回值的线程 Java线程:新特征-锁(上) Java线程:新特征-锁(下) ...
由生产者/消费者问题看JAVA多线程,让我们更加的了解多线程问题