Java Doc for ProcessBuilder.java in  » 6.0-JDK-Core » lang » java » lang » Java Source Code / Java DocumentationJava Source Code and Java Documentation

Java Source Code / Java Documentation
1. 6.0 JDK Core
2. 6.0 JDK Modules
3. 6.0 JDK Modules com.sun
4. 6.0 JDK Modules com.sun.java
5. 6.0 JDK Modules sun
6. 6.0 JDK Platform
7. Ajax
8. Apache Harmony Java SE
9. Aspect oriented
10. Authentication Authorization
11. Blogger System
12. Build
13. Byte Code
14. Cache
15. Chart
16. Chat
17. Code Analyzer
18. Collaboration
19. Content Management System
20. Database Client
21. Database DBMS
22. Database JDBC Connection Pool
23. Database ORM
24. Development
25. EJB Server geronimo
26. EJB Server GlassFish
27. EJB Server JBoss 4.2.1
28. EJB Server resin 3.1.5
29. ERP CRM Financial
30. ESB
31. Forum
32. GIS
33. Graphic Library
34. Groupware
35. HTML Parser
36. IDE
37. IDE Eclipse
38. IDE Netbeans
39. Installer
40. Internationalization Localization
41. Inversion of Control
42. Issue Tracking
43. J2EE
44. JBoss
45. JMS
46. JMX
47. Library
48. Mail Clients
49. Net
50. Parser
51. PDF
52. Portal
53. Profiler
54. Project Management
55. Report
56. RSS RDF
57. Rule Engine
58. Science
59. Scripting
60. Search Engine
61. Security
62. Sevlet Container
63. Source Control
64. Swing Library
65. Template Engine
66. Test Coverage
67. Testing
68. UML
69. Web Crawler
70. Web Framework
71. Web Mail
72. Web Server
73. Web Services
74. Web Services apache cxf 2.0.1
75. Web Services AXIS2
76. Wiki Engine
77. Workflow Engines
78. XML
79. XML UI
Java
Java Tutorial
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
C# / C Sharp
C# / CSharp Tutorial
ASP.Net
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
PHP
Python
SQL Server / T-SQL
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
Java Source Code / Java Documentation » 6.0 JDK Core » lang » java.lang 
Source Cross Reference  Class Diagram Java Document (Java Doc) 


java.lang.Object
   java.lang.ProcessBuilder

ProcessBuilder
final public class ProcessBuilder (Code)
This class is used to create operating system processes.

Each ProcessBuilder instance manages a collection of process attributes. The ProcessBuilder.start() method creates a new Process instance with those attributes. The ProcessBuilder.start() method can be invoked repeatedly from the same instance to create new subprocesses with identical or related attributes.

Each process builder manages these process attributes:

  • a command, a list of strings which signifies the external program file to be invoked and its arguments, if any. Which string lists represent a valid operating system command is system-dependent. For example, it is common for each conceptual argument to be an element in this list, but there are operating systems where programs are expected to tokenize command line strings themselves - on such a system a Java implementation might require commands to contain exactly two elements.
  • an environment, which is a system-dependent mapping from variables to values. The initial value is a copy of the environment of the current process (see System.getenv ).
  • a working directory. The default value is the current working directory of the current process, usually the directory named by the system property user.dir.
  • a redirectErrorStream property. Initially, this property is false, meaning that the standard output and error output of a subprocess are sent to two separate streams, which can be accessed using the Process.getInputStream and Process.getErrorStream methods. If the value is set to true, the standard error is merged with the standard output. This makes it easier to correlate error messages with the corresponding output. In this case, the merged data can be read from the stream returned by Process.getInputStream , while reading from the stream returned by Process.getErrorStream will get an immediate end of file.

Modifying a process builder's attributes will affect processes subsequently started by that object's ProcessBuilder.start() method, but will never affect previously started processes or the Java process itself.

Most error checking is performed by the ProcessBuilder.start() method. It is possible to modify the state of an object so that ProcessBuilder.start() will fail. For example, setting the command attribute to an empty list will not throw an exception unless ProcessBuilder.start() is invoked.

Note that this class is not synchronized. If multiple threads access a ProcessBuilder instance concurrently, and at least one of the threads modifies one of the attributes structurally, it must be synchronized externally.

Starting a new process which uses the default working directory and environment is easy:

 Process p = new ProcessBuilder("myCommand", "myArg").start();
 

Here is an example that starts a process with a modified working directory and environment:

 ProcessBuilder pb = new ProcessBuilder("myCommand", "myArg1", "myArg2");
 Map<String, String> env = pb.environment();
 env.put("VAR1", "myValue");
 env.remove("OTHERVAR");
 env.put("VAR2", env.get("VAR1") + "suffix");
 pb.directory(new File("myDir"));
 Process p = pb.start();
 

To start a process with an explicit set of environment variables, first call java.util.Map.clear Map.clear() before adding environment variables.
since:
   1.5




Constructor Summary
public  ProcessBuilder(List<String> command)
     Constructs a process builder with the specified operating system program and arguments.
public  ProcessBuilder(String... command)
     Constructs a process builder with the specified operating system program and arguments.

Method Summary
public  ProcessBuildercommand(List<String> command)
     Sets this process builder's operating system program and arguments.
public  ProcessBuildercommand(String... command)
     Sets this process builder's operating system program and arguments.
public  List<String>command()
     Returns this process builder's operating system program and arguments.
public  Filedirectory()
     Returns this process builder's working directory.
public  ProcessBuilderdirectory(File directory)
     Sets this process builder's working directory.
public  Map<String, String>environment()
     Returns a string map view of this process builder's environment. Whenever a process builder is created, the environment is initialized to a copy of the current process environment (see System.getenv ).
 ProcessBuilderenvironment(String[] envp)
    
public  booleanredirectErrorStream()
     Tells whether this process builder merges standard error and standard output.

If this property is true, then any error output generated by subprocesses subsequently started by this object's ProcessBuilder.start() method will be merged with the standard output, so that both can be read using the Process.getInputStream method.

public  ProcessBuilderredirectErrorStream(boolean redirectErrorStream)
     Sets this process builder's redirectErrorStream property.

If this property is true, then any error output generated by subprocesses subsequently started by this object's ProcessBuilder.start() method will be merged with the standard output, so that both can be read using the Process.getInputStream method.

public  Processstart()
     Starts a new process using the attributes of this process builder.

The new process will invoke the command and arguments given by ProcessBuilder.command() , in a working directory as given by ProcessBuilder.directory() , with a process environment as given by ProcessBuilder.environment() .

This method checks that the command is a valid operating system command.



Constructor Detail
ProcessBuilder
public ProcessBuilder(List<String> command)(Code)
Constructs a process builder with the specified operating system program and arguments. This constructor does not make a copy of the command list. Subsequent updates to the list will be reflected in the state of the process builder. It is not checked whether command corresponds to a valid operating system command.


Parameters:
  command - The list containing the program and its arguments
throws:
  NullPointerException - If the argument is null



ProcessBuilder
public ProcessBuilder(String... command)(Code)
Constructs a process builder with the specified operating system program and arguments. This is a convenience constructor that sets the process builder's command to a string list containing the same strings as the command array, in the same order. It is not checked whether command corresponds to a valid operating system command.


Parameters:
  command - A string array containing the program and its arguments




Method Detail
command
public ProcessBuilder command(List<String> command)(Code)
Sets this process builder's operating system program and arguments. This method does not make a copy of the command list. Subsequent updates to the list will be reflected in the state of the process builder. It is not checked whether command corresponds to a valid operating system command.


Parameters:
  command - The list containing the program and its arguments This process builder
throws:
  NullPointerException - If the argument is null



command
public ProcessBuilder command(String... command)(Code)
Sets this process builder's operating system program and arguments. This is a convenience method that sets the command to a string list containing the same strings as the command array, in the same order. It is not checked whether command corresponds to a valid operating system command.


Parameters:
  command - A string array containing the program and its arguments This process builder



command
public List<String> command()(Code)
Returns this process builder's operating system program and arguments. The returned list is not a copy. Subsequent updates to the list will be reflected in the state of this process builder.

This process builder's program and its arguments



directory
public File directory()(Code)
Returns this process builder's working directory. Subprocesses subsequently started by this object's ProcessBuilder.start() method will use this as their working directory. The returned value may be null -- this means to use the working directory of the current Java process, usually the directory named by the system property user.dir, as the working directory of the child process.

This process builder's working directory



directory
public ProcessBuilder directory(File directory)(Code)
Sets this process builder's working directory. Subprocesses subsequently started by this object's ProcessBuilder.start() method will use this as their working directory. The argument may be null -- this means to use the working directory of the current Java process, usually the directory named by the system property user.dir, as the working directory of the child process.


Parameters:
  directory - The new working directory This process builder



environment
public Map<String, String> environment()(Code)
Returns a string map view of this process builder's environment. Whenever a process builder is created, the environment is initialized to a copy of the current process environment (see System.getenv ). Subprocesses subsequently started by this object's ProcessBuilder.start() method will use this map as their environment.

The returned object may be modified using ordinary java.util.Map Map operations. These modifications will be visible to subprocesses started via the ProcessBuilder.start() method. Two ProcessBuilder instances always contain independent process environments, so changes to the returned map will never be reflected in any other ProcessBuilder instance or the values returned by System.getenv System.getenv .

If the system does not support environment variables, an empty map is returned.

The returned map does not permit null keys or values. Attempting to insert or query the presence of a null key or value will throw a NullPointerException . Attempting to query the presence of a key or value which is not of type String will throw a ClassCastException .

The behavior of the returned map is system-dependent. A system may not allow modifications to environment variables or may forbid certain variable names or values. For this reason, attempts to modify the map may fail with UnsupportedOperationException or IllegalArgumentException if the modification is not permitted by the operating system.

Since the external format of environment variable names and values is system-dependent, there may not be a one-to-one mapping between them and Java's Unicode strings. Nevertheless, the map is implemented in such a way that environment variables which are not modified by Java code will have an unmodified native representation in the subprocess.

The returned map and its collection views may not obey the general contract of the Object.equals and Object.hashCode methods.

The returned map is typically case-sensitive on all platforms.

If a security manager exists, its SecurityManager.checkPermission checkPermission method is called with a RuntimePermission ("getenv.*") permission. This may result in a SecurityException being thrown.

When passing information to a Java subprocess, system properties are generally preferred over environment variables.

This process builder's environment
throws:
  SecurityException - If a security manager exists and itsSecurityManager.checkPermission checkPermissionmethod doesn't allow access to the process environment
See Also:   Runtime.exec(String[]String[]java.io.File)
See Also:   System.getenv



environment
ProcessBuilder environment(String[] envp)(Code)



redirectErrorStream
public boolean redirectErrorStream()(Code)
Tells whether this process builder merges standard error and standard output.

If this property is true, then any error output generated by subprocesses subsequently started by this object's ProcessBuilder.start() method will be merged with the standard output, so that both can be read using the Process.getInputStream method. This makes it easier to correlate error messages with the corresponding output. The initial value is false.

This process builder's redirectErrorStream property



redirectErrorStream
public ProcessBuilder redirectErrorStream(boolean redirectErrorStream)(Code)
Sets this process builder's redirectErrorStream property.

If this property is true, then any error output generated by subprocesses subsequently started by this object's ProcessBuilder.start() method will be merged with the standard output, so that both can be read using the Process.getInputStream method. This makes it easier to correlate error messages with the corresponding output. The initial value is false.


Parameters:
  redirectErrorStream - The new property value This process builder



start
public Process start() throws IOException(Code)
Starts a new process using the attributes of this process builder.

The new process will invoke the command and arguments given by ProcessBuilder.command() , in a working directory as given by ProcessBuilder.directory() , with a process environment as given by ProcessBuilder.environment() .

This method checks that the command is a valid operating system command. Which commands are valid is system-dependent, but at the very least the command must be a non-empty list of non-null strings.

If there is a security manager, its SecurityManager.checkExec checkExec method is called with the first component of this object's command array as its argument. This may result in a SecurityException being thrown.

Starting an operating system process is highly system-dependent. Among the many things that can go wrong are:

  • The operating system program file was not found.
  • Access to the program file was denied.
  • The working directory does not exist.

In such cases an exception will be thrown. The exact nature of the exception is system-dependent, but it will always be a subclass of IOException .

Subsequent modifications to this process builder will not affect the returned Process .

A new Process object for managing the subprocess
throws:
  NullPointerException - If an element of the command list is null
throws:
  IndexOutOfBoundsException - If the command is an empty list (has size 0)
throws:
  SecurityException - If a security manager exists and itsSecurityManager.checkExec checkExecmethod doesn't allow creation of the subprocess
throws:
  IOException - If an I/O error occurs
See Also:   Runtime.exec(String[]String[]java.io.File)
See Also:   SecurityManager.checkExec(String)



Methods inherited from java.lang.Object
native protected Object clone() throws CloneNotSupportedException(Code)(Java Doc)
public boolean equals(Object obj)(Code)(Java Doc)
protected void finalize() throws Throwable(Code)(Java Doc)
final native public Class getClass()(Code)(Java Doc)
native public int hashCode()(Code)(Java Doc)
final native public void notify()(Code)(Java Doc)
final native public void notifyAll()(Code)(Java Doc)
public String toString()(Code)(Java Doc)
final native public void wait(long timeout) throws InterruptedException(Code)(Java Doc)
final public void wait(long timeout, int nanos) throws InterruptedException(Code)(Java Doc)
final public void wait() throws InterruptedException(Code)(Java Doc)

w___w__w__._ja_v__a2___s___._co__m_ | Contact Us
Copyright 2003 - 08 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.