- 浏览: 580314 次
- 性别:
- 来自: 苏州
文章分类
- 全部博客 (206)
- Flask (1)
- JavaScript (3)
- Core Java (41)
- XML (1)
- Oracle (11)
- 软件安装及环境配置 (0)
- 其它 (9)
- 面试/笔试 (5)
- 项目 (0)
- JDBC (11)
- Servlet (4)
- MySql (4)
- JNDI (0)
- Hibernate (11)
- Java模式和构架设计 (0)
- Web设计 (22)
- JSP (8)
- Struts (13)
- Tomcat (2)
- Marven (2)
- SVN (2)
- Swing/AWT (1)
- jQuery (2)
- ExtJS (8)
- Python (22)
- Flex (1)
- Django (7)
- 算法 (5)
- English (1)
- Twisted (1)
- Linux (3)
- Rails (1)
- SVG (3)
- PostgreSQL (1)
- wait()和notify()¬ifyAll()必须工作在加锁(synchronized)的代码块中。
- 抢占的锁和释放的锁要是同一对象的锁,否则抛出IllegalMonitorStateException。
Stack.java
package thread; public class Stack { private Object[] objs; private int index = 0; public Stack() { this(3); } public Stack(int length) { this.objs = new Object[length]; } public void push(Object obj) { synchronized (this) { while (index == this.objs.length) { try { this.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } for (int i = 0; i < 100000; i++) {}; objs[index] = obj; index++; this.notifyAll(); } } public Object pop() { synchronized (this) { while (index == 0) { try { this.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } --index; for (int i = 0; i < 100000; i++) {}; Object value = this.objs[index]; this.notifyAll(); return value; } } }
Producer.java
package thread; import java.util.Random; public class Producer extends Thread{ private Stack stack; public Producer(Stack stack){ this.stack = stack; } @Override public void run() { Random ran = new Random(); for (int i = 0; i < 20; i++) { Object obj = ran.nextInt(200); stack.push(obj); System.out.println(obj+" 压入成功。" ); try { Thread.sleep(300); } catch (InterruptedException e) { e.printStackTrace(); } } } }
Customer.java
package thread; public class Customer extends Thread{ private Stack stack; public Customer(Stack stack) { this.stack = stack; } @Override public void run() { for (int i = 0; i < 20; i++) { Object value = stack.pop(); System.out.println(value+" 弹出成功。"); try { Thread.sleep(300); } catch (InterruptedException e) { e.printStackTrace(); } } } }
Test.java
package thread; public class Test { public static void main(String[] args) { Stack stack = new Stack(); for (int i = 0; i < 20; i++) { Producer p = new Producer(stack); p.setName("producerThread"); p.start(); } for (int i = 0; i < 20; i++) { Customer c = new Customer(stack); c.setName("customerThread"); c.start(); } } }
发表评论
-
线程的停止
2010-12-24 00:30 1150既然stop()是不被推荐的 ... -
JDK环境变量的配置
2010-12-19 11:03 973JDK环境变量的配置 (1)JAVA_HOME C:\Pro ... -
自定义异常
2010-12-10 12:09 1207内置异常不可能始终足以捕获所有错误,因此需要用户自定义的异常类 ... -
编写异常的规范
2010-12-10 11:35 1168错误的编码: OutputStreamWriter out ... -
内部类
2010-12-06 16:51 1137内部类详解 1、定义 一个类的定义放在另一个类的内部,这个 ... -
抽象类和接口的区别
2010-12-06 16:47 1064含有abstract修饰符的class 即为抽象类,abstr ... -
人工抛出异常
2010-12-06 16:35 2099Java异常类对象除在程序执行过程中出现异常时由系统自动生成并 ... -
Java异常处理机制
2010-12-06 16:30 10611.Java程序的执行过程中如出现异常,会自动生成一个异常类对 ... -
Java的垃圾回收原理与机制
2010-12-06 16:12 1164JAVA中的对象是在堆上分配,而在堆上分配存储空间的方式是昂贵 ... -
Comparable和Comparator接口
2010-12-06 15:13 1709当需要排序的集合或数组不是单纯的数字型时,通常可以使用Comp ... -
手工打包JAR
2010-12-06 12:57 22391.把准备打包的.java文件集中到一个目录中例如c:\sou ... -
Java集合类
2010-12-03 14:26 1299Collection接口 Collection是 ... -
Java Socket 初步详解
2010-11-08 09:05 1078网络编程的基本模型就 ... -
Java中newString(abc)创建几个对象的解释
2010-11-02 10:04 1898String str=new String("abc ... -
Java日期处理
2010-10-19 17:17 14301.有关日期时间的类 1.java.util.Date ... -
线程同步
2010-10-17 21:17 1098一个方法被synchronized修饰:当程序执行此方法时,当 ... -
线程的状态及生命周期
2010-10-17 20:29 1522线程共有6种状态;在某一时刻只能是这6种状态之一。这些状态由T ... -
sleep()、wait()、yield()、join()方法 浅析
2010-10-17 18:54 1102线程退出最好自己实现,在运行状态中一直检验一个状态,如果这 ... -
RandomAccessFile类的应用
2010-10-17 10:39 1779文件存取通常是顺序的,每在文件中存取一次,文件的读 ... -
利用Externalizable接口实现对象的自定义序列化
2010-10-17 10:12 1313SerializedUser.java import jav ...
相关推荐
此外,pv操作还可以广泛应用于各种生产者消费者问题的解决中,使得系统更为可靠和高效。 pv操作是解决生产者与消费者问题的常用方法之一。通过pv操作,我们可以确保生产者进程和消费者进程之间的同步,避免数据的...
操作系统中的生产者与消费者问题是多线程编程中的一个经典模型,它主要研究的是如何有效地在共享资源之间协调生产者和消费者的行为,以避免数据竞争和死锁等问题。在这个C#编写的实例中,我们将深入探讨这个问题及其...
在这个实验“进程同步实验——生产者与消费者问题算法实现”中,我们探讨了一个经典的并发问题:生产者-消费者问题。 生产者-消费者问题是多线程编程中的一种典型应用场景,模拟了实际生产流水线的过程。在这个问题...
总的来说,"操作系统生产者与消费者问题Java简单模拟实现"这个项目提供了一个直观的多线程编程实例,帮助我们理解和实践Java中的线程同步技术,这对于理解和解决实际并发问题具有重要意义。通过分析这个项目,我们...
例如,在生产者与消费者问题中,有一个缓冲区作为共享资源,生产者将产品放入缓冲区,而消费者则从缓冲区取出产品。为了保证数据的一致性,必须确保在任何时候,缓冲区要么只允许一个生产者写入,要么只允许一个消费...
### 进程同步与互斥:生产者与消费者问题 #### 一、基础知识与概念解析 **1.1 操作系统的基本概念** 操作系统(Operating System, OS)是计算机系统的核心软件,负责管理和协调计算机硬件资源及软件资源。它通过...
生产者与消费者问题(操作系统)
在生产者与消费者问题中,可以使用两个信号量分别控制生产者和消费者对缓冲区的操作。 - **互斥锁**:另一种常见的同步机制,用于确保同一时间只有一个进程能够访问临界资源。在本例中,可以使用互斥锁来防止生产者...
该程序是我写的博客“一起talk C栗子吧(第一百零六回:C语言实例--生产者与消费者问题二)”的配套程序,共享给大家使用
“生产者---消费者”问题是最著名的进程同步问题。它描述了一组生产者向一组消费者提供产品,它们共享一个有界缓冲区,生产者向其中投放产品,消费者从中取得产品。它是许多相互合作进程的抽象,如输入进程与计算...
大连理工大学软件学院操作系统实验 生产者与消费者问题代码 热乎出炉 复制粘贴即能运行 !
操作系统概念第七版第七单元实验 生产者与消费者问题linux下pthread代码 注释:此为刚完成的代码 请下载者主动修改 谢谢---mayy
操作系统实验中的“生产者与消费者问题”是一个经典的多线程同步问题,源于计算机科学理论,主要探讨如何在并发环境中有效地管理共享资源。本实验通过使用C#编程语言来模拟这个问题,帮助学生理解线程同步、互斥访问...
在解压缩后的"proandcom"文件中,可能包含了进一步的代码示例或详细的解释,你可以查看这些文件以加深对生产者消费者问题的理解。同时,为了优化性能和避免死锁,编写多线程程序时,需要遵循良好的设计原则,例如...
### 生产者与消费者问题详解 #### 一、生产者-消费者问题背景 生产者-消费者问题是计算机科学中一个非常经典的进程同步问题。它通常用来描述一组“生产者”线程向缓冲区添加数据,而另一组“消费者”线程从缓冲区...