- 浏览: 1251080 次
- 性别:
- 来自: 杭州
文章分类
- 全部博客 (399)
- 心情故事 (12)
- java (115)
- linux (55)
- 关系型数据库 (35)
- struts,jsf,spring (11)
- jdbc,hibernate,ibatis (11)
- jsp,jstl,c:tag,标签库 (2)
- ejb,webservice (1)
- tomcat,jboss,jetty,weblogic,websphere (15)
- java网络编程 (6)
- java线程 (0)
- js,jquery,json,xml,dom,html.regex (25)
- 设计模式 (6)
- BUG记录 (2)
- ant (2)
- jsp,servlet (4)
- swing (6)
- lucene+nutch (6)
- log4j (2)
- windows doc (2)
- ruby (1)
- ruby on rails (3)
- 操作系统网络 (18)
- apache 错误 (1)
- tomcat (10)
- jboss (9)
- jetty (9)
- weblogic (9)
- websphere (10)
- apache (2)
- AIX的iostat命令查看系统磁盘的使用情况 (1)
- oracle 统计一个表格有多少列 (1)
- Exception in thread "main" java.security.KeyStoreException: Windows-MY not found (1)
- jsp (1)
- jstl (1)
- c:tag (1)
- 标签库 (1)
- struts (1)
- jsf (1)
- spring (2)
- oracle,sqlplus (2)
- sqlplus (2)
- show errors (1)
- proc (1)
- function (1)
- ORA-06544: PL/SQL: internal error (1)
- arguments: [55916] (1)
- [] (7)
- 终端身份实施文档 (1)
- 重装系统之后飞鸽传书只能看到自己 (1)
- vsftp "上传 553 Could not create file" (1)
- startWebLogic.sh启动失败,提示Error initializing Embedded LDAP Server (1)
- java agent 注册为 windows 服务 (1)
- centos (1)
- svn (1)
- apr (1)
- apr-util (1)
- activemq (2)
- oracle (5)
- mysql (3)
- nosql (3)
- NSIS (1)
- windows wmic (1)
- c 指针 (1)
- c c++ (0)
- jmeter (0)
- 性能测试 (0)
- linux,备份 (2)
- C++ ,Virtual (1)
- windows dos (1)
- android (2)
- 大数据,云计算 (1)
- JVM垃圾收集 (1)
- jdbc (2)
- invoke (1)
- hibernate (1)
- ibatis (1)
- 个人开源项目源码收藏 (1)
- 批处理 (1)
- Mongodb mapreduce (8)
- kettle (1)
- Mongodb capped (1)
- mongodb gridfs (1)
- Mongodb 入门基础知识 (1)
- mongodb (8)
- hadoop2.5.1 (1)
- hadoop (4)
- eclipse (1)
- hdfs fs (1)
- elipse hadoop plugin (1)
- PHP相关知识 (1)
- js (1)
- jquery (1)
- json (1)
- xml (1)
- dom (1)
- html.regex (1)
- 网络知识 (1)
- nginx (1)
- docker (1)
- 测试 (1)
- nodejs (1)
- iptables (1)
- linux gitlab (1)
最新评论
-
July01:
最近了解到一款StratoIO打印控件,功能如下:1、Html ...
web页面调用window.print()函数实现打印的功能 -
hxdtech:
非常感谢!
我在学习ibatis时的培训ppt -
zmwxiaoming:
what 能连数据库不错
SOLR的学习整理 -
springdata_springmvc:
java程序语言学习教程 地址http://www.zuida ...
java获取当前操作系统的信息 -
huanzei:
整理的不错,
oracle lpad函数
在Java
语言中,提供了各种各样的输入输出流(stream),使我们能够很方便的对数据进行操作,其中,管道
(pipe)流是一种特殊的流,用于在不同线程(threads)间直接传送数据。一个线程发送数据到输出管道
,另一个线程从输入管道
中读数据。通过使用管道
,实现不同线程间的通讯。 无需求助于类似临时文件
之类的东西。本文在简要介绍管道
的基本概念后,将以一个具体的实例pipeapp加以详细说明。
1.管道
的创建与使用
Java
提供了两个特殊的专门的类专门用于处理管道
,它们就是pipedinputstream类和pipeoutputstream类。
Pipedinputstream代表了数据在管道
中的输出端,也就是线程向管道
读数据的一端;pipeoutputstream代表了数据在管道
中的输入端,也就是线程向管道
写
数据的一端,这两个类一起使用可以提供数据的管道
流。
为了创建一个管道
流,我们必须首先创建一个pipeoutstream对象,然后,创建pipeinputstream对象,实例如下:
pipeout= new pipedyoutstream(); pipein= new pipedputsteam(pipepout);
一旦创建了一个管道
后,就可以象操作文件
一样对管道
进行数据的读写
。
2.演示程序: pipeapp
应用程序由三个程序组成:主线程(pipeapp.Java
)及由主线程启动的两个二级线程(ythread.Java
和zthread.Java
),它们使用管道
来处理数据。程序从一个内容为一行一行"x"字母的"input.txt"文件
中读取数据,使用管道
传输数据,第一次是利用线程ythread将数据"x"转换为"y",最后利用线程zthread将"y"转换为"z",之后,程序在屏幕上显示修改后的数据。
主线程 (pipeapp.Java
)
在main()方法中,程序首先创建一个应用对象:pipeapp pipeapp=new pipeapp();
由于程序中流操作都需要使用IOException异常处理,所以设置了一个try块。在try中,为了从源文件
中读取数据,程序为"input.txt"文件
创建了一个输入流Xfileln,:
fileinputstream xfileln= new fileinputstream("input.txt");
新的输入流传递给changetoy()方法,让线程ythread能读取该文件
:
inputstream ylnpipe =pipeapp.changetoy(xfileln);
changetoy()方法创建将输入数据"x"改变到"y"的线程ythread,并返回该线程的输入管道
:
inputstream zlnpipe = pipeapp.changetoz(ylnpipe);
changetoz()方法启动将数据从"y"改变到"z"的线程zehread,主程序将使用从changetoz()返回的输入管道
。得到以修改的数据。
然后,程序将管道
输入流定位到datainputstream对象,使程序能够使用readline()方法读取数据:
datainputstream inputstream = new datainputstream(zlnpiepe);
创建了输入流以后,程序就可以以行一行的读取数据病显示在屏幕上。
String str= inputstream.readline(); While(str!=null) { system.out.println(str); str=inputstream.readline(); } |
显示完成之后,程序关闭输入流:
inputstream.close(); changetoy()方法 |
changetoy()方法首先通过传递一个参数inputstream给datainputstream对象来定位资源的输入流,使程序能使用readline()方法从流中读取数据:
datainputstream xfileln =new datainutstream(inputstream);
然后,changetoy()创建输出管道
和输入管道
:
pipeoutstream pipeout = new pipeoutputstream(); pipeinputstream pipeln = new pipedinputsteam(pipeout); |
为了能够使用println()方法输出修改的后的文本行到管道
,程序将输出管道
定位到printstream对象:
printstream printstream = new printstream(pipeout);
现在,程序可以创建将数据从x改变到y的线程,该线程是ythread类的一个对象,他传递两个参数:输入文件
(xfileln)和输出管道
(调用printstream)
ythread ythread =new thread(xfileln,printstream);
之后,程序启动线程:
changetoz()方法
changetoz()方法与changetoy()方法很相似,他从changetoy()返回的输入流开始:
datainputstream yfileln= new datainputstream(inputstream);
程序创建一个新的管道
:
pipedoutstream pipeout2 = new pipedoutputstream(); pipedinputstream pipeln2 = new pipedinputsream(pipeout2); |
该线程通过这个新的管道 发出修改后的数据(输入流pipeln2)给主程序。
源程序如下:
import Java.io.* class pipeapp { public static void main(string[] args) { pipeapp pipeapp=new pipeapp(); try { fileinputstream xfile =new fileinputstream("input.txt"); inputstream ylnpipe = pipeapp.changetoy(xfileln); inputstream zlnpipe=pipeapp.changetoz(ylnpipe); system.out.println(); system.out.println("here are the results"); system.out.pringln(); datainputstream inputstream = nes datainputstream(zlnpipe); string str = inputstream.readline(); while (str!=null) { system.out.println(str); str=inputstream.readline(); } inputstream.close(); } catch(exception e) { system.out.println(e.tostring()); } } public inputstream changetoy(inputstream inputstream) { try { datainputstream pipeout = new datainputsteam(inputstream); pipedoutstream pipeout = new pipedoutputstream(); pipedlnsteam pipeln = new pipedlnputstream(pipeout); printstream printstream = new printstream(pipeout); ythread ythread = new ythread(xfileln,printstream); ythread.start(); return pipeln; } catch(exeption e) { system.out.println(x.tostring()); } return null; } public inputstream changetoz(inputstream inputsteam) { try { datainputstream yfileln = new datainputstream(inputstream); pipeoutputstream pipeln2 = new pipedinputstream(pipeout2); printrstream printstream2 = new printsteam(pipeout2); zthread zthread = new zthread(yfileln,printstream2); zthread.start(); return pipeln2; } catch(exception e) { system.out.println(e.tostring()); } return null; } }
Ythread类和Zthread类
由于ythread类与zthread类基本一样,在此仅以ythread为例加以说明。
Ythread的构造器接收两个参数:输入的文件
和第一个管道
的输出端,构造器存储这两个参数作为类的数据成员:
Ythread(datainputstream xfileln,pringstream printstream) { this.xfileln = xfileln; this.printstream = printstream; } |
线程通过run()方法来处理数据。首先读取一行数据,确保xstring不为空的情况下循环执行:
string xstring = xfileln.readline();
每读一行数据,完成一次转换
string ystring = xstring.replace('x','y');
然后将修改后的数据输出到管道
的输出端:
prinstream.prinrln(ystring);
为了确保所有缓冲区的数据完全进入管道
的输出端:
pringstram.flush();
循环完成后,线程关闭管道
输出流:
pringstram.close();
ythread类的源程序如下:
import Java.io.*; class ythread exteads thread { datainputstream xfileln; pringstream printstream; ythread(datainputstream xfileln,pringstream.printstream) { this.xfileln = xfileln; this.printstream = printstream; } public void run() { try { string xstring = xfileln.readline(); while(xstring!=null) { string ystring= xstring.replace('x','y'); printstream.pringln(ystring); printstream.flush(); xstring= xfileln.readline(); } printstream.close(); } catch{ioexception e} { system.out.println(e.tostring()); } } }
发表评论
-
centos6.5 hadoop伪分布式搭建
2017-01-10 10:41 25打算整理下machine learn ,再次安装 ... -
springboot
2016-12-29 11:13 2381微服务,现在是一个越来越热的东西,软件架构发展到 ... -
elk安装记录
2016-12-27 18:04 980在centos6.5上安装elk,记录下安装过程和 ... -
dubbo服务框架
2016-12-23 15:40 480上一篇文章介绍了zookeeper,作为服务 ... -
zookeeper服务注册中心配置
2016-12-22 11:40 1663用zookeeper有一段时间了,把配置做下简 ... -
OS X 安装java开发环境
2016-12-03 23:29 591... -
关于Restful API 的设计
2015-06-12 13:32 2275Restful API的流行,很大程度上被当前的移动 ... -
Jvisualvm远程连接tomcat配置:
2015-05-12 16:16 781JvisualVm 监控远程Tomcat,需要在To ... -
jdbc mybatis hibernate springJDBC的一些理解
2015-01-15 17:10 7064... -
Java 的ExecutorService
2015-01-15 11:45 1216早期在Java5以前,我们做多线程程序,一般都 ... -
spring的IOC和AOP
2015-01-14 16:47 2351关于Spring,大家都是耳熟 ... -
java 的线程安全
2014-12-30 14:43 959现代CPU基本都是多核,支持 ... -
JVM ClassLoader
2014-12-25 16:33 936JVM在加载类的时候,都是通过ClassLoad ... -
minor Gc ,Full Gc
2014-12-24 17:22 2102在发生Minor gc之前,虚拟机会先检查老年带最 ... -
Java的主要垃圾回收器
2014-12-24 16:33 1307对象 ... -
JVM的内存结构的一点理解
2014-12-24 11:30 777... -
利用生产者消费者模式实现串行的任务并行化
2014-12-22 17:48 1235试想,一个省有100个处理节点需要 ... -
利用生产者消费者模式实现串行的任务并行化
2014-12-22 17:48 0试想,一个省有100个处理节点需要 ... -
关于Linux的Ulimit参数
2014-12-22 12:13 1275JVM 64位平台与32位平台 ... -
一种表格数据比对的方法
2014-12-19 16:59 1047假设有连个库,一个是生产库,一个是备份库,在一个特 ...
相关推荐
在Java中,管道(Pipe)流提供了一种有效的方法,允许数据从一个线程传递到另一个线程,从而实现线程间的通信。管道通常由两个流组成:一个输出流用于写入数据,另一个输入流用于读取数据。这种方式使得数据可以在不...
#### 十、Java中利用管道实现线程间的通讯 - **管道创建与使用**: - 创建管道对象,如`Pipe`。 - 通过`sink()`和`source()`方法实现数据传输。 #### 十一、实战Java多线程编程精要之高级支持 - **线程组**: - ...
ThreadImRunnable.java 继承Runnable接口实现多线程 mulThread.java 创建多个线程对象的类 demoJoin.java 演示使用join()以确保主线程最后结束 clicker.java 一个计数用的线程类 demoPri.java 调用上面这个类...
在编程领域,多线程是实现并发执行任务的重要机制,特别是在多核处理器系统中,它能充分利用硬件资源,提高程序的执行效率。本资源“多线程快速入门”旨在帮助初学者快速掌握多线程的基本概念和应用。下面将详细阐述...
在Java平台上开发此类程序,开发者通常会利用Java的Socket编程、多线程以及音频处理技术来实现这一功能。下面我们将深入探讨这个话题。 首先,Java Socket编程是实现远程通信的基础。在打电话程序中,Socket充当了...
在“Java版QQ”中,开发者可能利用了Java的多线程技术,以实现用户之间的并发聊天功能。多线程使得程序能够同时处理多个任务,提高了系统效率。此外,Java的异常处理机制确保了程序在面对错误时能够有序地进行错误...
这个Demo项目“通过AndroidAccessory实现两个手机的USB通讯Demo”正是展示了如何利用这种模式来实现在两台Android设备间的数据传输。下面将详细讲解Android Accessory模式的工作原理、实现步骤以及如何在这个Demo中...
在本Java实验“飞鸽”项目中,我们将深入探讨如何利用Java技术实现在局域网内的即时通讯功能,包括单点聊天、群聊以及文件的发送与接收。这个实验不仅涵盖了基本的网络编程概念,还涉及到多线程、对象序列化和数据...
4. **Pipe(管道)**:用于两个线程间的数据传输。 ### NIO服务端模板结构 1. **初始化ServerSocketChannel**:首先创建ServerSocketChannel,并绑定到指定的端口,然后将其注册到Selector上,监听ACCEPT事件。 2...
通过将JESS的输入输出设备重定向到JAVA IO流,再结合多线程管道通讯技术和Servlet技术,可以在不改变现有专家系统源代码的情况下,将其部署到Web环境中,从而实现与用户的实时交互。 ##### 3.2 关键代码示例 虽然...
在本文中,我们将深入探讨 Netty 实时通讯的原理与应用,以及如何利用它构建 WebSocket 服务。 WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议,为 Web 应用提供了低延迟、双向通信的能力。Netty 提供了对...
在学习Java的过程中,读者需要理解Java语言的面向对象特性,了解如何利用Java进行多线程编程,掌握Java在文件输入输出、网络通信、数据库操作等方面的应用。同时,也要熟悉Java在企业级应用开发中的重要技术规范,...
SCADA(Supervisory Control and Data Acquisition)系统是用于监控和控制工业过程的重要工具,尤其在能源行业,如石油和天然气管道中应用广泛。在这个基于Java的石油管线SCADA系统中,我们将探讨如何利用Java技术...
段页式存储管理结合了分段和分页的优点,既提供了逻辑地址空间的分段管理,又实现了内存的分页分配,提高了内存的利用率和程序的灵活性。 2. **进程间的通讯方式及区别** 进程间通信(IPC)是操作系统中的一个重要...
5. **心跳机制**:为了检测客户端是否在线,通常会在聊天室中实现心跳机制。服务器定时向客户端发送心跳请求,如果在一定时间内未收到回应,则认为客户端已离线。 6. **安全性**:为了保护聊天内容的安全,可以集成...
8.3.1利用Thread的子类创建线程270 8.3.2实现Runnable接口创建线程272 8.3.3使用isAlive()和join()等待子线程结束273 8.3.4设置线程优先级275 8.4线程的通信与协调277 8.4.1线程的互斥277 8.4.2线程的同步279 ...
在本文中,我们将深入探讨如何利用 Netty 实现客户端与服务器之间的通信。 首先,我们要理解 Netty 的核心概念。Netty 的设计模式基于 Actor 模型,它使用非阻塞 I/O(NIO)来处理并发连接。这使得 Netty 能够高效...
- **线程模型**: 允许开发者根据需求自定义线程模型,如单线程模式、多线程池模式等。 - **安全性**: 支持SSL/TLS/StartTLS加密传输。 - **性能监控**: 集成了JMX工具,便于系统管理和性能监控。 - **Spring集成**: ...
JXSE(Java JXTA Secure Edge)是JXTA的实现,它提供了安全的P2P通信框架。"jxse-src-2.5"是JXSE的源码包,版本为2.5,这个源码库为我们提供了深入研究和理解JXTA和P2P即时通讯机制的宝贵资料。 1. **JXTA架构** ...
NIO(Non-blocking I/O,非阻塞I/O)是Java平台中的一种I/O模型,与传统的BIO(Blocking I/O,阻塞I/O)相比,NIO在处理高并发、大数据传输时表现出更高的效率和更好的性能。NIO的核心概念包括通道(Channel)、缓冲...