📄 如何用java来实现“生产者―消费者”问题-java面向对象 - it电子教育门户 高端java培训.htm
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0060)http://www.mldn.cn/articleview/2007-1-7/article_view_279.htm -->
<HTML><HEAD><TITLE>如何用JAVA来实现“生产者―消费者”问题/JAVA面向对象 - IT电子教育门户 高端JAVA培训</TITLE>
<STYLE type=text/css>BODY {
FONT-SIZE: 12px
}
TD {
FONT-SIZE: 12px
}
TH {
FONT-SIZE: 12px
}
.STYLE1 {
FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #003399
}
.STYLE2 {
FONT-SIZE: 14px
}
</STYLE>
<META content="MSHTML 6.00.2900.2180" name=GENERATOR>
<META content=g0IGIjwMtoTt4TksXOL7QykvujGWD7D0AoPDPWEsjRs= name=verify-v1>
<META http-equiv=Content-Type content="text/html; charset=utf-8">
<META http-equiv=Content-Language content=zh-CN>
<META content=java培训,mldn,JAVA教程,北京JAVA培训,IT电子教育门户,北京JAVA培训,java语法
name=keywords>
<META content=生产者和消费者问题是从操作系统中的许多实际同步问题中抽象出来的具有&nbsp;代表性的问题。
name=description>
<META content=all name=robots>
<META content=www.mldn.cn,所有版权 name=Copyright>
<STYLE type=text/css>BODY {
MARGIN: 0px
}
</STYLE>
<STYLE type=text/css>IMG {
BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
A:link {
TEXT-DECORATION: none
}
BODY {
FONT-SIZE: 12px
}
TD {
FONT-SIZE: 12px
}
TH {
FONT-SIZE: 12px
}
A:visited {
TEXT-DECORATION: none
}
A:hover {
TEXT-DECORATION: underline
}
A:active {
TEXT-DECORATION: none
}
.input {
BORDER-RIGHT: #acb4b7 1px solid; PADDING-RIGHT: 0px; BORDER-TOP: #9aa1a9 1px solid; PADDING-LEFT: 0px; FONT-SIZE: 14px; BACKGROUND-ATTACHMENT: fixed; BACKGROUND-IMAGE: url(image/search/input.gif); PADDING-BOTTOM: 5px; BORDER-LEFT: #9aa1a9 1px solid; WIDTH: 550px; PADDING-TOP: 5px; BORDER-BOTTOM: #acb4b7 1px solid; BACKGROUND-REPEAT: no-repeat; HEIGHT: 30px; TEXT-ALIGN: left
}
</STYLE>
</STYLE><!--系统js,必须调用-->
<SCRIPT src="如何用JAVA来实现“生产者―消费者”问题-JAVA面向对象 - IT电子教育门户 高端JAVA培训.files/public.js"
type=text/javascript></SCRIPT>
<LINK title=rss href="http://www.mldn.cn/rssfeed.asp" type=application/rss+xml
rel=alternate></HEAD>
<BODY><!--头部代码结束-->
<TABLE cellSpacing=0 cellPadding=0 width=890 align=center border=0>
<TBODY>
<TR>
<TD width=274><A href="http://www.mldn.cn/"><IMG height=79 alt=MLDN
src="如何用JAVA来实现“生产者―消费者”问题-JAVA面向对象 - IT电子教育门户 高端JAVA培训.files/logo.gif"
width=274 border=0></A></TD>
<TD width=616><IMG height=79
src="如何用JAVA来实现“生产者―消费者”问题-JAVA面向对象 - IT电子教育门户 高端JAVA培训.files/main_r1_c2.gif"
width=616 useMap=#Map border=0></TD></TR></TBODY></TABLE><MAP name=Map><AREA
shape=RECT coords=8,22,45,49 href="http://www.mldn.cn/"><AREA shape=RECT
coords=53,22,113,50
href="http://www.mldn.cn/articlelist/article_3_adddate_desc_1.htm"><AREA
shape=RECT coords=116,20,177,51
href="http://www.mldn.cn/articlelist/article_4_adddate_desc_1.htm"><AREA
shape=RECT alt=java培训 coords=181,21,242,51
href="http://www.mldn.cn/articlelist/article_58_adddate_desc_1.htm"><AREA
shape=RECT coords=245,21,307,52 href="http://www.mldnjava.cn/"><AREA
shape=RECT coords=309,21,374,51 href="http://www.zhinangtuan.net.cn/"><AREA
shape=RECT target=_blank coords=376,21,439,50
href="http://www.mldnjava.cn/java/index.htm"></MAP>
<SCRIPT language=javascript></SCRIPT>
<TABLE cellSpacing=0 cellPadding=0 width=890 align=center border=0>
<TBODY>
<TR>
<TD><A href="http://www.mldnjava.cn/java/" target=blank><IMG height=150
alt=远程JAVA培训
src="如何用JAVA来实现“生产者―消费者”问题-JAVA面向对象 - IT电子教育门户 高端JAVA培训.files/index_banner.jpg"
width=890></A></TD></TR></TBODY></TABLE>
<TABLE cellSpacing=0 cellPadding=0 width=890 align=center bgColor=#f1f1f1
border=0>
<TBODY>
<TR>
<TD vAlign=top width=670>
<TABLE cellSpacing=1 cellPadding=0 width="99%" align=center
bgColor=#cccccc border=0>
<TBODY>
<TR>
<TD bgColor=#ffffff>
<TABLE cellSpacing=0 cellPadding=0 width="98%" align=center
border=0>
<TBODY>
<TR>
<TD bgColor=#e4e4e4 colSpan=2><A
href="http://www.mldn.cn/"><B>IT电子教育门户 高端JAVA培训</B></A> -=>
<A
href="http://www.mldn.cn/articlelist/article_4_adddate_desc_1.htm"><B>资源中心</B></A>
-=> <A
href="http://www.mldn.cn/articlelist/article_11_adddate_desc_1.htm"><B>JAVA
SE技术专区</B></A> -=> <A
href="http://www.mldn.cn/articlelist/article_18_adddate_desc_1.htm"><B>JAVA面向对象</B></A>
-=> 正文</TD></TR>
<TR>
<TD align=middle colSpan=2 height=40>
<H1>如何用JAVA来实现“生产者―消费者”问题</H1></TD></TR>
<TR align=middle>
<TD colSpan=2 height=40>
<SCRIPT type=text/javascript><!--
google_ad_client = "pub-8263014661871932";
google_ad_width = 468;
google_ad_height = 60;
google_ad_format = "468x60_as";
google_ad_type = "text_image";
//2007-02-14: 新闻内容页面上面
google_ad_channel = "8423241514";
google_color_border = "FFFFFF";
google_color_bg = "FFFFFF";
google_color_link = "333333";
google_color_text = "333333";
google_color_url = "003366";
//--></SCRIPT>
<SCRIPT
src="如何用JAVA来实现“生产者―消费者”问题-JAVA面向对象 - IT电子教育门户 高端JAVA培训.files/show_ads.js"
type=text/javascript>
</SCRIPT>
</TD></TR>
<TR>
<TD colSpan=2 height=40> 发布日期:2007-1-7
19:19:00 发布者:[<A
href="http://www.mldn.cn/florilegium.jtml?a_name=IT电子教育门户&a_id=0"
rel=external>IT电子教育门户</A>] 评论:[
<SCRIPT
src="如何用JAVA来实现“生产者―消费者”问题-JAVA面向对象 - IT电子教育门户 高端JAVA培训.files/error.htm"
type=text/javascript></SCRIPT>
] 浏览:
<SCRIPT
src="C:\Documents and Settings\elibuser\桌面\面向对象学习文档\如何用JAVA来实现“生产者―消费者”问题-JAVA面向对象 - IT电子教育门户 高端JAVA培训.files\error(1).htm"
type=text/javascript></SCRIPT>
</TD></TR>
<TR>
<TD colSpan=2><SPAN class=STYLE2>
<DIV id=article>
<DIV>如何用JAVA来实现“生产者―消费者”问题</DIV>
<DIV> 生产者和消费者问题是从操作系统中的许多实际同步问题中抽象出来的具有
<BR>代表性的问题。它反映了操作系统中典型的同步例子。
<BR><BR> 生产者进程(进程由多个线程组成)生产信息,例如它可以是计算进程。消费
<BR>者进程使用信息,它可以是输出打印进程。由于生产者和消费者彼此独立,且运
<BR>行速度不确定,所以很可能出现生产者已产生了信息而消费者却没有来得及接受
<BR>信息这种情况。为此,需要引入由一个或者若干个存储单元组成的临时存储区,
<BR>以便存放生产者所产生的信息,平滑进程间由于速度不确定所带来的问题。这个
<BR>临时存储区叫做缓冲区,通常用一维数组来表示。
<BR><BR> 由一个或若干个存储单元组成的缓冲区叫作“有穷缓冲区”。下面我们来分
<BR>析一下有穷缓冲的生产者和消费者的例子。
<BR><BR> 假设有多个生产者和多个消费者,它们共享一个具有n个存储单元的有穷缓冲
<BR>区Buffer(0……n-1),这是一个环形队列。其队尾指针Rear指向当前信息应存放
<BR>的位置(Buffer[Rear]),队首指针Front指向当前取出信息的位置(Buffer[front
<BR>])。生产者进程总是把信息存放在Buffer[Rear]中,消费者进程则总是从Buffer
<BR>[Rear]中取出信息。如果想使生产者进程和消费者进程协调合作,则必须使它们
<BR>遵循如下规则:
<BR><BR> 1) 只要缓冲区有存储单元,生产者都可往其中存放信息;当缓冲区已满时,
<BR>若任意生产者提出写要求,则都必须等待;
<BR><BR> 2) 只要缓冲区中有消息可取,消费者都可从缓冲区中取出消息;当缓冲区为
<BR>空时,若任意消费者想取出信息,则必须等待;
<BR><BR> 3) 生产者们和消费者们不能同时读、写缓冲区。
<BR><BR> 用JAVA 实现“生产者-消费者”问题的代码如下:
<BR><BR> class MonitorTest{
<BR><BR> static int produce_speed=200;
<BR><BR> static int consume_speed=200;
<BR><BR> public static void main (String [] args){
<BR><BR> if(args.length>0)
<BR><BR> produce_speed=Integer.parseInt(args[0]);
<BR><BR> if(args.length>1)
<BR><BR> consume_speed=Integer.parseInt(args[1]);
<BR><BR> Monitor monitor=new Monitor();
<BR><BR> new Producer(monitor,produce_speed);
<BR><BR> new Consumer(monitor,consume_speed);
<BR><BR> try{
<BR><BR> Thread.sleep(4000);
<BR><BR> }catch(InterruptedException e){}
<BR><BR> System.exit(0); <BR><BR> }
<BR><BR> } <BR><BR> class Monitor {
<BR><BR> int Buffer_Length=10;
<BR><BR> int[] Buffer=new int[Buffer_Length];
<BR><BR> int Item;
<BR><BR> int Count=0,Rear=0,Front=0;
<BR><BR> //get buffer
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -