Java进程通讯
- 管道(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.classtry{
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());
} - (非进程,而是线程)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进程通讯的更多相关文章
- android中跨进程通讯的4种方式
转自:http://blog.csdn.net/lyf_007217/article/details/8542359 帖子写的很好.看来一遍,试了一遍,感觉太有意义.必须转过来! android中跨进 ...
- Chris Richardson微服务翻译:构建微服务之微服务架构的进程通讯
Chris Richardson 微服务系列翻译全7篇链接: 微服务介绍 构建微服务之使用API网关 构建微服务之微服务架构的进程通讯(本文) 微服务架构中的服务发现 微服务之事件驱动的数据管理 微服 ...
- Android查缺补漏(IPC篇)-- 款进程通讯之AIDL详解
本文作者:CodingBlock 文章链接:http://www.cnblogs.com/codingblock/p/8436529.html 进程间通讯篇系列文章目录: Android查缺补漏(IP ...
- 故障重现, JAVA进程内存不够时突然挂掉模拟
背景,服务器上的一个JAVA服务进程突然挂掉,查看产生了崩溃日志,如下: # Set larger code cache with -XX:ReservedCodeCacheSize= # This ...
- 死磕内存篇 --- JAVA进程和linux内存间的大小关系
运行个JAVA 用sleep去hold住 package org.hjb.test; public class TestOnly { public static void main(String[] ...
- android 史上最简单易懂的跨进程通讯(Messenger)!
不需要AIDL也不需要复杂的ContentProvider,也不需要SharedPreferences或者共享存储文件! 只需要简单易懂的Messenger,它也称为信使,通过它可以在不同进程中传递m ...
- Linux下java进程CPU占用率高-分析方法
今天登陆同事的一台gateway 开始以为hive环境登陆不了了,仔细一看看了下是因为机器很卡,我每次等几秒没登陆就ctrl+c了,看了下是有个java进程cpu:340.4% mem:14.6% ...
- Linux下java进程CPU占用率高分析方法
Linux下java进程CPU占用率高分析方法 在工作当中,肯定会遇到由代码所导致的高CPU耗用以及内存溢出的情况.这种情况发生时,我们怎么去找出原因并解决. 一般解决方法是通过top命令找出消耗资源 ...
- Linux删除多个java进程的其中一个
一.背景: Linux后台运行了多个Java程序,进程名都是java. 执行pkill java会一次性杀掉所有的java进程. 二.解决思路: 先通过一定的检索条件,定位出指定的java进程 然后解 ...
随机推荐
- Hybird应用开发实践(一)使用原生/cordova混合项目
最近准备尝试hybird开发原生应用,因为公司的项目本来就是原生开发的,所以准备选择cordova作为webview嵌入原生项目的开发方式.这里就以mac上整合ios项目为例. 1. 创建cordov ...
- Java多线程(学习篇)
Java多线程:(学习篇) 1.什么是线程 2.线程状态 3.线程中断 4.线程交互 5.同步机制 6.锁机制 7.堵塞队列与堵塞栈 8.条件变量.原子量.线程池等 9.线性安全类和Callable与 ...
- C# winform DatagridView 的简单操作
数据显示操作: dgBill.Columns[0].DataPropertyName = "key1"; dgBill.Columns[1].DataPropertyName = ...
- JSP EL表达式 param、paramValues的使用
JSP EL表达式 param.paramValues的使用: <%@ page language="java" import="java.util.*" ...
- 利用moment为基础,基于DOM实现一个多个倒计时同时进行的js库方便使用
moment非常强大,提供了很多时间方法的封装,项目需要一个小倒计时的功能,网上找了很多不合适,决定自己写一个,直接上代码 //定义一个立即执行的函数(function () { var Ticts= ...
- MyBatis-Generator的配置说明和使用
关于MyBatis: MyBatis Generator (MBG) 是一个Mybatis的代码生成器 MyBatis 和 iBATIS. 他可以生成Mybatis各个版本的代码,和iBATIS 2. ...
- github使用介绍
github是个比较火的分布式版本管理工具,适合多人协同工作,感觉比svn好.下面简单介绍一下github使用以及把本地代码和github同步的方法. 首先注册账号 https://github.co ...
- 编写JQuery插件-2
继续上一节的代码 (function(){ /* code */ })() 来我们介绍一下吧,首先定义一个匿名函数 fnction(){/* 这里放置代码 */} 然后用括号括起来, (fnction ...
- [笔记]FTRL与Online Optimization
1. 背景介绍 最优化求解问题可能是我们在工作中遇到的最多的一类问题了:从已有的数据中提炼出最适合的模型参数,从而对未知的数据进行预测.当我们面对高维高数据量的场景时,常见的批量处理的方式已经显得力不 ...
- 数据库MySQL调优实战经验总结
MySQL 数据库的使用是非常的广泛,稳定性和安全性也非常好,经历了无数大小公司的验证.仅能够安装使用是远远不够的,MySQL 在使用中需要进行不断的调整参数或优化设置,才能够发挥 MySQL 的最大 ...