Java编程技巧(信号量,管道)

博客围绕Java编程展开,重点涉及多线程和Semaphore相关内容。Semaphore是JDK中的工具,在多线程编程里有重要作用,可用于控制并发访问资源的数量等,助力开发者更好地进行多线程程序开发。
Java编程技巧(信号量,管道)
本文出自:http://noc.cstnet.net.cn/ 瞿宏阳 (2001-06-08 15:00:00)

一、信号量 

在进行多线程编程时,经常要使用同步互斥机构,但java本身没有提供的同步互斥机构,仅提供了两个与同步互斥有关的方法:wait()和notify(),可以用来设计信号量类:mySemaphore,它是按照Dijkstra提出的计数信号量的思想设计的。 

mySemaphore有两个最重要的成员方法:P()和V()。这两个方法实际就实现了信号量的P操作和V操作。具体描述如下: 

public synchronized void P(){ 

semaphore--; 

if(semaphore<0){ 

try{ 

wait(); 

}catch(InterruptedException ie){} 





public synchronized void V(){ 

semaphore++; 

if(semaphore<=0) 

notify(); 



其中,semaphore变量记录了信号量的状态,wait()方法相当于block原语,用于阻塞线程的执行,notify()方法相当于wakeup原语,用于唤醒线程恢复运行。由于这两个方法定义为synchronized,这样java虚拟机可保证这两个方法的原子执行,从而实现了P、V操作。 

二、管道 

并发程序的多个线程之间的通讯通常是使用管道进行,jdk提供了两个管道类:PipedInpuStream和PipedOutputStream,前者用于输入,后者用于输出。这两种管道应该是能够多次连接和关闭,在实现过程中,却发现它们在关闭后,不能重新建立连接。经过仔细调试后,发现jdk的源代码在处理关闭时释放资源存在着缺陷,因此需要编写自己的管道类:MyPipedInputStream和MyPipedOutputStream。这两个类直接从InputStream和OutputStream继承而来,其成员方法与实现基本与PipedInputStream和PipedOutputStream一致,只是在处理关闭时,将类中的成员变量的值恢复成未连接时的初始值。另外,原有的管道了提供的管道容量只有1024个字节,在传输数据量较大时,可能会发生溢出,而在自己的管道类中可以任意设置管道容量,例如可以根据需要把管道容量设为64KB。以下仅给出了相应的关闭例程: 

1.MyPipedInputStream 

public void close() throws IOException { 

in = -1; 

out = 0; 

closedByReader = true; 

connected = false; 

closed = true; 

buffer = new byte[PIPE_SIZE]; 



2.MyPipedOutputStream 

public void close() throws IOException { 

if (sink != null) { 

sink.receivedLast(); 

sink.closed = true; 



sink = null; 

connected = false; 

}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值