Java线程之Producer
Producer-Consumer Pattern的参与者:
1. Data参与者
被Producer参与者所创建,并由Consumer参与者所使用。
2. Producer(生产者)参与者
创建Data参与者,并将其传递给Channel参与者。
3. Consumer(消费者)参与者
从Channel参与者获取Data参与者。
4. Channel(通道)参与者
Channel参与者从Producer参与者处接收Data参与者,并将其保管起来。并应Consumer参与者的要求,将Data参与者传送出去。
为了确保安全性,Producer参与者与Consumer参与者要对访问进行共享排斥。
在Producer-Consumer Pattern中,肩负保护安全性使命的是Channel参与者。Channel参与者进行线程之间的共享互斥,让Producer参与者能够正确的将Data参与者送到Consumer参与者手上。
这里,虽然分离了Producer和Consumer之间的交互,Producer参与者不需要等Consumer参与者处理完Data,就可以继续去制造下一个Data,Channel参与者作为Producer和Consumer之间的缓冲区。但是Channel参与者的容量也是有限的,也就是说,当Consumer消费Data的速度小于Producer制造Data的速度时,Channel中的Data数量会持续增加。这里需要对Channel的容量加以控制,否则可能会最后因为内存不足而使得Producer制造不出Data。对于Producer参与者来说,在Channel容量不足的情况下,要予以等待。
引申:
1. 因为Channel参与者的中介,使得Producer和Consumer的多条线程协调合作。
线程为了协调合作,所以必须进行共享互斥,使共享的东西不被损坏。而线程的共享互斥,就是为了让相处合作才进行的。
线程的合作要想“放在中间的东西”,线程的互斥要想“应该保护的东西”
2. 因为Channel参与者的中介,可以使Producer制造出来的多个Data以不同的顺序传递给Consumer。
常见的传递机制有:
-- 队列, 最先收到的先传
-- 堆栈, 最后收到的先传
-- 优先队列, “优先”的东西先传
相关文档:
Java学习从入门到精通
一、 JDK (Java Development Kit)
JDK是整个Java的核心,包括了Java运行环境(Java Runtime Envirnment),一堆Java工具和Java基础的类库(rt.jar)。不论什么Java应用服务器实质都是内置了某个版本的JDK。因此掌握JDK是学好Java的第一步。最主流的J ......
这是一个C/S之间通信的例子,在JDK1.4下测试通过.
//服务器端源程序tcpserver.java
import java.io.*;
import java.net.*;
public class tcpserver
{
public static void main(String[] args) throws IOException
{
......
最近学习java用到了JList,对于向JList中添加数据,困扰了好久,上网查给的答案都没个合适的,问了老师才弄明白些,总结如下:
1.使用Vector:首先把你的数据项都存放在Vector中,然后调用JList的setListData()方法,将Vector添加到JList中
Vector vt=new Vector();
JList list=new JLis ......
A.使用关键字this的准则:
1.在构造器中,如果要使用关键字this,那么,必须放在第一行,否则将导致一个编译错误。
2.构造方法引用this指向正在执行方法的类的实例。静态方法不能使用this关键字,因为静态方法不属于类的实例,所以this也就没有什么东西去指向。构造器的this指向同一个类中,不同参数列表的另外一 ......
Java语言的输入输出功能是十分强大而灵活的,美中不足的是看上去输入输出的代码并不是很简洁,因为你往往需要包装许多不同的对象。在Java类库中,IO部分的内容是很庞大的,因为它涉及的领域很广泛:标准输入输出,文件的操作,网络上的数据流,字符串流,对象流,zip文件流....本文的目的是为大家做一个简要的介绍。
......