1. 管道(Pipe):管道可用于具有亲缘关系进程间的通信,允许一个进程和另一个与它有共同祖先的进程之间进行通信。
    创建子进程Java有两种方式

    //第一种
    Runtime rt = Runtime.getRuntime();
    Process process = rt.exec("java -jar app2.jar");
    //第二种
    ProcessBuilder pb = new ProcessBuilder("java", "-jar","app2.jar");
    Process p = pb.start();

    第二种方式操作更方便,实例如下。
    父进程App.class

    try{
    ProcessBuilder pb=new ProcessBuilder("java -jar app2.jar".split(" "));
    pb.directory(new File("e:/temp/clean_day/jar/"));
    //标准错误和输入流合并为输入流
    pb.redirectErrorStream(true);
    //创建子进程
    Process p=pb.start(); //使用Process的输入流接收子进程发送的消息
    BufferedReader br=new BufferedReader(new InputStreamReader(p.getInputStream()));
    //使用Process的输出流向子进程发送消息,并把PrintWriter设置为自动flush.
    PrintWriter wr=new PrintWriter(new OutputStreamWriter(p.getOutputStream()),true);
    String lineStr;
    while((lineStr=br.readLine())!=null){
    System.out.println("收到子进程的消息:"+lineStr);
    //向子进程发送消息
    wr.println(System.currentTimeMillis());
    }
    wr.close();
    br.close();
    }catch(Exception ex){
    System.out.println(ex.getMessage());
    }

    子进程App2.class

    try{
    System.out.println("子进程启动成功");
    System.out.println(System.currentTimeMillis()); //利用标准输入来接收父进程发送的消息
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    String lineStr;
    while ((lineStr = br.readLine()) != null) {
    System.out.println("child\t"+lineStr);
    }
    br.close();
    }catch(Exception ex){
    System.out.println(ex.getMessage());
    }
  2. (非进程,而是线程)PipedInputStream、PipedOutStream、PipedReader、PipedWriter管道流
    public class App {
    
    	public static void main(String[] args) {
    PpWriter wr=new PpWriter();
    PpReader rd=new PpReader(wr); Thread wrth=new Thread(wr);
    wrth.start(); Thread rdth=new Thread(rd);
    rdth.start();
    }
    } /**
    * 管道写
    * App.java:Temp
    * 2015年3月26日
    * @author kevin.zhai(韩旭)
    */
    class PpWriter implements Runnable{
    private PipedWriter pipedWriter; public PpWriter(){
    this.pipedWriter=new PipedWriter();
    } @Override
    public void run() {
    try {
    while(true){
    //因为读使用了readline,因此这里要换行
    String sendStr=System.currentTimeMillis()+"\r\n";
    this.pipedWriter.write(sendStr);
    System.out.println("父发送:"+sendStr);
    Thread.sleep(1000);
    }
    } catch (IOException | InterruptedException e) {
    e.printStackTrace();
    }
    } public PipedWriter getPipedWriter() {
    return pipedWriter;
    }
    } /**
    * 管道读
    * App.java:Temp
    * 2015年3月26日
    * @author kevin.zhai(韩旭)
    */
    class PpReader implements Runnable{
    private PipedReader pipedReader; public PpReader(PpWriter ppWriter){
    try {
    //读需要先和写建立连接,否则报异常:Pipe not connected
    this.pipedReader=new PipedReader(ppWriter.getPipedWriter());
    } catch (IOException e) {
    e.printStackTrace();
    }
    }
    @Override
    public void run() { try(BufferedReader br=new BufferedReader(this.pipedReader)){
    while(true){
    System.out.println("子接收:"+br.readLine());
    }
    } catch (IOException e) {
    e.printStackTrace();
    }
    }
    }

Java进程通讯的更多相关文章

  1. android中跨进程通讯的4种方式

    转自:http://blog.csdn.net/lyf_007217/article/details/8542359 帖子写的很好.看来一遍,试了一遍,感觉太有意义.必须转过来! android中跨进 ...

  2. Chris Richardson微服务翻译:构建微服务之微服务架构的进程通讯

    Chris Richardson 微服务系列翻译全7篇链接: 微服务介绍 构建微服务之使用API网关 构建微服务之微服务架构的进程通讯(本文) 微服务架构中的服务发现 微服务之事件驱动的数据管理 微服 ...

  3. Android查缺补漏(IPC篇)-- 款进程通讯之AIDL详解

    本文作者:CodingBlock 文章链接:http://www.cnblogs.com/codingblock/p/8436529.html 进程间通讯篇系列文章目录: Android查缺补漏(IP ...

  4. 故障重现, JAVA进程内存不够时突然挂掉模拟

    背景,服务器上的一个JAVA服务进程突然挂掉,查看产生了崩溃日志,如下: # Set larger code cache with -XX:ReservedCodeCacheSize= # This ...

  5. 死磕内存篇 --- JAVA进程和linux内存间的大小关系

    运行个JAVA 用sleep去hold住 package org.hjb.test; public class TestOnly { public static void main(String[] ...

  6. android 史上最简单易懂的跨进程通讯(Messenger)!

    不需要AIDL也不需要复杂的ContentProvider,也不需要SharedPreferences或者共享存储文件! 只需要简单易懂的Messenger,它也称为信使,通过它可以在不同进程中传递m ...

  7. Linux下java进程CPU占用率高-分析方法

    今天登陆同事的一台gateway 开始以为hive环境登陆不了了,仔细一看看了下是因为机器很卡,我每次等几秒没登陆就ctrl+c了,看了下是有个java进程cpu:340.4%  mem:14.6%  ...

  8. Linux下java进程CPU占用率高分析方法

    Linux下java进程CPU占用率高分析方法 在工作当中,肯定会遇到由代码所导致的高CPU耗用以及内存溢出的情况.这种情况发生时,我们怎么去找出原因并解决. 一般解决方法是通过top命令找出消耗资源 ...

  9. Linux删除多个java进程的其中一个

    一.背景: Linux后台运行了多个Java程序,进程名都是java. 执行pkill java会一次性杀掉所有的java进程. 二.解决思路: 先通过一定的检索条件,定位出指定的java进程 然后解 ...

随机推荐

  1. firefox-Developer开发者站点——关于Object.create()新方法的介绍

    https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/create Objec ...

  2. 解剖 Elasticsearch 集群 - 之三

    解剖 Elasticsearch 集群 - 之三 本篇文章是一系列涵盖 Elasticsearch 底层架构和原型示例的其中一篇.在本篇文章中,我们会讨论 Elasticsearch 如何提供准实时搜 ...

  3. Bootstrap 输入组

    Bootstrap 输入组: <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...

  4. 分享一个基于thrift的java-rpc框架

    简单介绍 这是一个简单小巧的Java RPC框架,适用于Java平台内.为系统之间的交互提供了.高性能.低延迟的方案.适合在集群数量偏少的情况下使用(50台以下集群环境).当然.它也可以在大型集群环境 ...

  5. python 的日志相关应用

    python日志主要用logging模块; 示例代码如下: #coding:utf-8 import logging class logger(): ''' %(asctime)s %(filenam ...

  6. KB奇遇记(3):IT现状

    2015年8月3号,终于告别了过去来到了KB. 公司给安排的住房是一间套房里的小房间,小的简直连坐的地方都没有了,中间一个大床将房间隔了两边,显得特别狭小.由于是刚来,我也不好要求太多.但就这个小房间 ...

  7. KB奇遇记(10):终章

    本来还想写一篇关于前CIO的著名言论,不过想想还是算了.博客空间宝贵,不乱恶心人了. 这篇博文是本系列<KB奇遇记>的最后一篇了. 虽然在KB公司有这么多的苦,但毕竟收获也很多,至少让我懂 ...

  8. 解决Ubuntu 16.04 软件中心闪退

    就是上面这个Ubuntu软件中心,类似如应用市场,今天不知怎么回事竟然抽风了,打开之后几秒就闪退了,导致我安装sublime一致失败,百度之后才知道这是16.04版本的一个毛病,按照我的性格,手机软件 ...

  9. WebForm 控件(二)

    控件 Calendar:日历控件 但是html代码量太大不适用 FileUpdate: 文件上传 HiddenField:隐藏域 Image: 图片  可以直接给URL 不适用可用html代码写 Ta ...

  10. WinForm 进程、线程

    一.进程 进程是一个具有独立功能的程序关于某个数据集合的一次运行活动. 它可以申请和拥有系统资源,是一个动态的概念,是一个活动的实体. Process 类,用来操作进程. 命名空间:using Sys ...