JavaTM Platform
Standard Ed. 6

java.lang
クラス Process

java.lang.Object
  上位を拡張 java.lang.Process

public abstract class Process
extends Object

ProcessBuilder.start() メソッドと Runtime.exec メソッドは、ネイティブなプロセスを作成し、Process のサブクラスのインスタンスを返します。このインスタンスを使って、プロセスの制御や、プロセス情報の取得が行えます。Process クラスは、プロセスからの入力、プロセスへの出力、プロセス完了の待機、プロセス終了状態の確認、およびプロセスの破棄 (終了) を実行するための各メソッドを提供します。

たとえば、ネイティブなウィンドウ処理プロセス、デーモンプロセス、Microsoft Windows 環境での Win16/DOS プロセス、あるいはシェルスクリプトといったプロセスです。作成されたサブプロセスは、自身の端末またはコンソールを持ちません。サブプロセスの標準入出力処理 (すなわち stdin、stdout、および stderr) は、3 つのストリーム (getOutputStream()getInputStream()getErrorStream()) によって親プロセスにリダイレクトされます。親プロセスはこれらのストリームを使って、サブプロセスに入力を送ったり、サブプロセスからの出力を取得したりします。ネイティブなプラットフォームには標準入出力ストリームに使うバッファーのサイズが限られるものもあるので、サブプロセスの入力ストリームの書き込みあるいはストリーム出力の読み込みが失敗した場合、サブプロセスはブロックされるか、デッドロック状態になる可能性があります。

Process オブジェクトへの参照がなくなった場合でも、サブプロセスは終了されず、非同期的に実行を続けます。

Process オブジェクトが表すプロセスの実行については、Process オブジェクトを所有する Java プロセスと非同期でなかったり、並行でなかったりしてもかまいません。

導入されたバージョン:
JDK1.0
関連項目:
ProcessBuilder, Runtime.exec(String[], String[], File)

コンストラクタの概要
Process()
           
 
メソッドの概要
abstract  void destroy()
          サブプロセスを終了します。
abstract  int exitValue()
          サブプロセスの終了コードを返します。
abstract  InputStream getErrorStream()
          サブプロセスのエラーストリームを取得します。
abstract  InputStream getInputStream()
          サブプロセスの入力ストリームを取得します。
abstract  OutputStream getOutputStream()
          サブプロセスの出力ストリームを取得します。
abstract  int waitFor()
          必要な場合に、この Process オブジェクトが表すプロセスが終了するまで現在のスレッドを待機させます。
 
クラス java.lang.Object から継承されたメソッド
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

コンストラクタの詳細

Process

public Process()
メソッドの詳細

getOutputStream

public abstract OutputStream getOutputStream()
サブプロセスの出力ストリームを取得します。ストリームへの出力は、この Process オブジェクトが表すプロセスの標準入力ストリームに渡されます。

実装にあたっての注意:出力ストリームのバッファー処理をお勧めします。

戻り値:
サブプロセスの通常の入力に接続された出力ストリーム

getInputStream

public abstract InputStream getInputStream()
サブプロセスの入力ストリームを取得します。ストリームは、この Process オブジェクトが表すプロセスの標準出力ストリームから渡されたデータを取得します。

実装にあたっての注意:入力ストリームのバッファー処理をお勧めします。

戻り値:
サブプロセスの通常の出力に接続された入力ストリーム
関連項目:
ProcessBuilder.redirectErrorStream()

getErrorStream

public abstract InputStream getErrorStream()
サブプロセスのエラーストリームを取得します。ストリームは、この Process オブジェクトが表すプロセスのエラー出力ストリームから渡されたデータを取得します。

実装にあたっての注意:入力ストリームのバッファー処理をお勧めします。

戻り値:
サブプロセスのエラーストリームに接続された入力ストリーム
関連項目:
ProcessBuilder.redirectErrorStream()

waitFor

public abstract int waitFor()
                     throws InterruptedException
必要な場合に、この Process オブジェクトが表すプロセスが終了するまで現在のスレッドを待機させます。サブプロセスがすでに終了している場合、このメソッドはただちに復帰します。サブプロセスが終了していない場合、呼び出し側スレッドはサブプロセスが終了するまでブロックされます。

戻り値:
プロセスの終了コード。通常は、0 は正常終了を示す
例外:
InterruptedException - 現在のスレッドが待機中にほかのスレッドによって割り込まれた場合、待機を終了して InterruptedException がスローされる

exitValue

public abstract int exitValue()
サブプロセスの終了コードを返します。

戻り値:
この Process オブジェクトが表すサブプロセスの終了コード。0 は正常終了を示す
例外:
IllegalThreadStateException - この Process オブジェクトが表すサブプロセスがまだ終了していない場合

destroy

public abstract void destroy()
サブプロセスを終了します。この Process オブジェクトが表すサブプロセスは強制終了されます。


JavaTM Platform
Standard Ed. 6

バグの報告と機能のリクエスト
さらに詳しい API リファレンスおよび開発者ドキュメントについては、Java SE 開発者用ドキュメントを参照してください。開発者向けの詳細な解説、概念の概要、用語の定義、バグの回避策、およびコード実例が含まれています。

Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。